当前位置: 首页 > news >正文

[QT编程系列-39]:用户界面UI - 样式表QSS与样式文件快速入门

目录

1. 概述

2. CSS

3. QSS示例

4. QT样式表文件使用方法与步骤

5. QT内置样式

6. QT常见基本样式


1. 概述

Qt提供了一种称为Qt样式表(Qt Style Sheets)的机制,可以用于自定义和美化Qt应用程序的用户界面(UI)

使用Qt样式表,你可以通过类似CSS的语法来定义UI元素的外观和布局,包括颜色、字体、边框、背景等。

以下是一些常用的Qt样式表属性和用法

  1. 选择器(Selectors):用于选择要应用样式的UI元素,可以使用对象名(object name)或类名(class name)作为选择器,也可以使用通配符和层级选择器。

    QPushButton {color: red;                    // 应用到所有QPushButton类型的按钮
    }QCheckBox#myCheckBox {font-size: 14px;               // 应用到objectName为"myCheckBox"的QCheckBox
    }QLabel.warning {background-color: yellow;      // 应用到class name为"warning"的QLabel
    }
    
  2. 属性设置:可以使用属性和值的形式来设置UI元素的外观。

    QPushButton {color: red;background-color: lightblue;    // 设置文本颜色和背景色border: 1px solid gray;         // 设置边框样式
    }QCheckBox:checked {color: green;                   // 设置选中状态的文本颜色
    }
    
  3. 盒模型属性:可以设置内边距(padding),外边距(margin),以及元素本身的尺寸和位置。

    QPushButton {padding: 5px;margin: 10px;width: 100px;height: 30px;                   // 设置内外边距、宽度和高度
    }QLabel {position: absolute;             // 设置绝对定位top: 50px;left: 100px;
    }
    
  4. 伪状态(Pseudo-states):用于设置特定状态下的样式,如鼠标悬停(hovered)、按下(pressed)等。

    QPushButton:hover {background-color: lightgray;    // 鼠标悬停时的背景颜色
    }QCheckBox:indeterminate {color: orange;                  // 设置不确定状态的文本颜色
    }QRadioButton:checked {image: url(checked.png);        // 设置选中状态时的自定义图像
    }
    

除了上述基本用法,Qt样式表还支持更多高级功能,如渐变、阴影效果、动画和自定义部件样式等

你可以通过在Qt应用程序中设置样式表来改变UI的外观和布局,使其更符合自己的需求和设计。

有关更详细的用法和属性,请查阅Qt文档中关于Qt样式表的部分。

2. CSS

CSS(Cascading Style Sheets)样式表是一种用于描述HTML或XML文档的展示样式的语言。它为网页提供了丰富的样式控制和布局选项,使网页开发人员能够轻松地定义文档元素的外观和排版。

以下是一些常用的CSS样式表属性和用法:

  1. 选择器(Selectors):用于选择要应用样式的HTML元素,可以使用标签名、class、id等作为选择器,也可以使用组合选择器。

    h1 {color: red;                    /* 应用到所有<h1>标签 */
    }.my-class {font-size: 14px;               /* 应用到class为"my-class"的元素 */
    }#my-id {background-color: yellow;      /* 应用到id为"my-id"的元素 */
    }p.my-class-fancy {color: blue;                   /* 应用到同时具有class "my-class-fancy"和<p>标签的元素 */
    }
    
  2. 属性设置:可以使用属性和值的形式来设置元素的外观。

    h1 {color: red;background-color: lightblue;    /* 设置文本颜色和背景颜色 */border: 1px solid gray;         /* 设置边框样式 */
    }.my-class {font-weight: bold;              /* 设置字体粗体 */
    }#my-id {text-decoration: underline;     /* 设置文本下划线 */
    }
    
  3. 盒模型属性:可以设置内边距(padding)、外边距(margin),以及元素本身的尺寸和位置。

    h1 {padding: 10px;margin-top: 20px;width: 300px;height: 50px;                   /* 设置内边距、外边距、宽度和高度 */
    }.my-class {position: absolute;             /* 设置绝对定位 */top: 50px;left: 100px;
    }
    
  4. 伪类(Pseudo-classes):用于设置特定状态下元素的样式,如鼠标悬停(:hover)、点击(:active)等。

    a:hover {color: green;                   /* 鼠标悬停时的文本颜色 */
    }input:focus {border: 2px solid blue;         /* 获得焦点时的边框样式 */
    }li:nth-child(odd) {background-color: lightgray;    /* 设置奇数位置的<li>元素的背景颜色 */
    }
    

CSS样式表还支持更多高级功能,如渐变、阴影效果、动画和媒体查询等。

使用CSS样式表,可以轻松地自定义网页的外观和布局,并使其具有吸引力和良好的用户体验。

对于更详细的属性和用法,请参考CSS的相关文档和教程。

3. QSS示例

以下是一些Qt样式表(QSS)的示例,展示了如何使用QSS来自定义Qt应用程序的UI外观:

  1. 设置全局样式:
/* 设置所有按钮的背景色和文本颜色 */
QPushButton {background-color: lightblue;color: white;
}/* 设置所有标签的字体和字体大小 */
QLabel {font-family: Arial, sans-serif;font-size: 14px;
}/* 设置窗口的背景图片 */
QWidget {background-image: url(background.jpg);background-repeat: no-repeat;background-position: center;
}

  1. 设置特定对象的样式:
/* 设置特定按钮的尺寸、背景颜色和边框样式 */
QPushButton#myButton {width: 100px;height: 30px;background-color: lightgreen;border: 1px solid darkgreen;
}/* 设置特定文本框的字体样式和内边距 */
QLineEdit.myLineEdit {font-family: Verdana, sans-serif;padding: 5px;
}/* 设置特定标签的文本颜色和背景颜色 */
QLabel.warningLabel {color: red;background-color: lightyellow;
}

  1. 使用伪状态和伪类:
/* 设置鼠标悬停时按钮的背景颜色 */
QPushButton:hover {background-color: lightgray;
}/* 设置按下按钮时的背景颜色和文本样式 */
QPushButton:pressed {background-color: darkgray;color: white;
}/* 设置表格中奇数行的背景颜色 */
QTableView QAbstractItemView::item:nth-child(odd) {background-color: lightgray;
}/* 设置选中行的背景颜色和文本颜色 */
QTableView QAbstractItemView::item:selected {background-color: navy;color: white;
}

这些示例只是QSS的一部分用法,其中展示了一些常见的样式设置。你可以根据自己的需求定制和设计Qt应用程序的样式表,以创建独特的UI外观。在应用QSS样式表时,通常需要使用setStyleSheet()函数将样式表应用于Qt对象或整个应用程序。详细的QSS语法和属性,请参考Qt的官方文档和样式表部分。

4. QT样式表文件使用方法与步骤

fangfgnaf在Qt中,你可以将样式表内容保存到一个独立的样式表文件中,然后在应用程序中引用该样式表文件来设置UI的外观。以下是使用样式表文件的步骤:

  1. 创建一个独立的样式表文件,通常使用.qss作为文件扩展名,比如styles.qss

  2. 在样式表文件中编写所需的样式规则,就像在QSS中编写样式一样。

    /* styles.qss */QPushButton {background-color: lightblue;color: white;
    }QLabel {font-family: Arial, sans-serif;font-size: 14px;
    }QWidget {background-image: url(background.jpg);background-repeat: no-repeat;background-position: center;
    }
    
  3. 应用程序中加载样式表文件,并应用于相应的Qt对象或整个应用程序。

    // main.cpp#include <QApplication>
    #include <QFile>int main(int argc, char *argv[])
    {QApplication app(argc, argv);// 创建一个样式表文件对象QFile styleFile(":/styles.qss");  // 根据实际的文件路径或资源路径进行修改if (styleFile.open(QFile::ReadOnly)){// 读取样式表文件内容QString styleSheet = QLatin1String(styleFile.readAll());// 设置样式表app.setStyleSheet(styleSheet);}// ... 创建和显示Qt对象return app.exec();
    }
    

    在上述示例中,styles.qss文件被读取并加载到styleSheet变量中,然后通过setStyleSheet()方法设置为应用程序的样式表:/styles.qss是资源路径,可以根据你的实际情况进行修改。

提示:如果要将样式表文件作为资源文件进行管理,可以在Qt项目中的.qrc文件中添加样式表文件并使用资源路径来引用。

通过使用样式表文件,你可以更好地组织和管理UI的样式规则,方便维护和重用。同时,你可以在不重新编译应用程序的情况下修改样式表文件,使得UI的外观可以灵活地调整和定制。

5. QT内置样式

Qt框架默认提供了几种内置的样式,你可以直接在应用程序中使用它们。

以下是几个常用的Qt现有样式:

  1. Fusion样式(默认样式):这是Qt框架默认的样式,它在不同的操作系统上提供了一致的外观。

  2. Windows样式:这是Windows操作系统的原生外观样式,可以在Qt应用程序中使用。

  3. macOS样式:这是macOS操作系统的原生外观样式,同样可以在Qt应用程序中使用。

  4. WindowsVista样式:仿效Windows Vista风格的外观样式。

  5. WindowsXP样式:仿效Windows XP风格的外观样式。

使用这些样式非常简单,只需在应用程序中设置所需的样式即可。以下是使用内置样式的示例代码:

#include <QApplication>
#include <QStyleFactory>int main(int argc, char *argv[])
{QApplication app(argc, argv);// 设置Fusion样式app.setStyle(QStyleFactory::create("Fusion"));// 设置Windows样式// app.setStyle(QStyleFactory::create("Windows"));// 设置macOS样式// app.setStyle(QStyleFactory::create("Macintosh"));// 设置WindowsVista样式// app.setStyle(QStyleFactory::create("WindowsVista"));// 设置WindowsXP样式// app.setStyle(QStyleFactory::create("WindowsXP"));// ... 创建和显示Qt对象return app.exec();
}

通过调用app.setStyle()方法并使用QStyleFactory::create()函数提供的内置样式之一,可以设置所需的样式。在上述示例中,使用了Fusion样式,你可以注释掉其他样式并选择你希望使用的样式。

除了这些内置样式,Qt还支持通过自定义QStyle子类来创建和使用自定义样式。这样可以实现完全定制的UI外观和行为。

6. QT常见基本样式

在Qt中,你可以使用样式表(Style Sheets)来定制和美化用户界面。以下是一些常见的样式,你可以通过样式表来实现它们:

  1. 背景颜色和背景图片:

    QWidget {background-color: lightblue;background-image: url(image.png);background-repeat: no-repeat;background-position: center;
    }
    
  2. 按钮样式:

    QPushButton {background-color: lightblue;color: white;border-radius: 5px;padding: 5px 10px;
    }
    
  3. 标签样式:

    QLabel {font-family: Arial, sans-serif;font-size: 14px;color: #333333;
    }
    
  4. 文本框样式:

    QLineEdit {padding: 5px;border: 1px solid #999999;border-radius: 3px;
    }
    
  5. 表格样式:

    QTableView {background-color: white;alternate-background-color: #f2f2f2;gridline-color: #cccccc;
    }
    
  6. 进度条样式:

    QProgressBar {background-color: #f0f0f0;border: 1px solid #999999;border-radius: 5px;
    }
    

以上只是一些常见的样式示例,你可以使用更多的CSS属性来实现更复杂的效果。在Qt的样式表中,你可以设置背景颜色、字体样式、边框样式、尺寸和间距等。同时,Qt还提供了更高级的样式定制能力,比如自定义绘制、状态切换和动画效果等。

要应用这些样式,你可以将样式表内容应用于相应的Qt对象,通过调用setStyleSheet()方法或使用Qt Designer界面编辑器。

希望这些常见的样式示例能够帮助你美化你的Qt用户界面。你可以根据实际需求和创意来定制更多独特的样式。

相关文章:

[QT编程系列-39]:用户界面UI - 样式表QSS与样式文件快速入门

目录 1. 概述 2. CSS 3. QSS示例 4. QT样式表文件使用方法与步骤 5. QT内置样式 6. QT常见基本样式 1. 概述 Qt提供了一种称为Qt样式表&#xff08;Qt Style Sheets&#xff09;的机制&#xff0c;可以用于自定义和美化Qt应用程序的用户界面&#xff08;UI&#xff09;。…...

机器学习和深度学习简述

一、人工智能、机器学习、深度学习的关系 近些年人工智能、机器学习和深度学习的概念十分火热&#xff0c;但很多从业者却很难说清它们之间的关系&#xff0c;外行人更是雾里看花。概括来说&#xff0c;人工智能、机器学习和深度学习覆盖的技术范畴是逐层递减的&#xff0c;三…...

diffusion model2 扩散模型的文本信息融合、交叉注意力机制、lora

前言 在上一篇文章中&#xff0c;我们剖析了diffusion model的原理&#xff0c;而在这一篇文章中&#xff0c;我们探讨与扩散模型有关的其他话题&#xff0c;包括扩散模型的unet是如何在推理噪声的过程中&#xff0c;融入文本信息的考量&#xff1f;其原理为交叉注意力机制&am…...

数据结构——二叉树

本章代码仓库&#xff1a;堆、二叉树链式结构 文章目录 &#x1f36d;1. 树&#x1f9c1;1.1 树的概念&#x1f9c1;1.2 树的结构 &#x1f36c;2. 二叉树&#x1f36b;2.1 二叉树的概念&#x1f36b;2.2 特殊的二叉树&#x1f36b;2.3 二叉树的性质&#x1f36b;2.4 二叉树的存…...

架构训练营学习笔记:5-3接口高可用

序 架构决定系统质量上限&#xff0c;代码决定系统质量下限&#xff0c;本节课串一下常见应对措施的框架&#xff0c;细节不太多&#xff0c;侧重对于技术本质有深入了解。 接口高可用整体框架 雪崩效应&#xff1a;请求量超过系统处理能力后导致系统性能螺旋快速下降 链式…...

【笔记】湖仓一体架构演进与发展

https://www.bilibili.com/video/BV1oF411F7rQ/?spm_id_from333.788.recommend_more_video.0&vd_sourcefa36a95b3c3fa4f32dd400f8cabddeaf...

政务云建设与应用解决方案[42页PPT]

导读&#xff1a;原文《政务云建设与应用解决方案[42页PPT]》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 完整版领取方式 完整版领取方式&#xff1a; 如需获取完…...

20天突破英语四级高频词汇——第①天

2&#xfeff;0天突破英语四级高频词汇~第一天加油(ง •_•)ง&#x1f4aa; &#x1f433;博主&#xff1a;命运之光 &#x1f308;专栏&#xff1a;英语四级高频词汇速记 &#x1f30c;博主的其他文章&#xff1a;点击进入博主的主页 目录 2&#xfeff;0天突破英语四级…...

【网络基础实战之路】基于MGRE多点协议的实战详解

系列文章传送门&#xff1a; 【网络基础实战之路】设计网络划分的实战详解 【网络基础实战之路】一文弄懂TCP的三次握手与四次断开 【网络基础实战之路】基于MGRE多点协议的实战详解 【网络基础实战之路】基于OSPF协议建立两个MGRE网络的实验详解 PS&#xff1a;本要求基于…...

K8s实战入门(三)

文章目录 3. 实战入门3.1 Namespace3.1.1 测试两个不同的名称空间之间的 Pod 是否连通性 3.2 Pod3.3 Label3.4 Deployment3.5 Service 3. 实战入门 本章节将介绍如何在kubernetes集群中部署一个nginx服务&#xff0c;并且能够对其进行访问。 3.1 Namespace Namespace是kuber…...

Linux-centos花生壳实现内网穿透

Linux-centos花生壳实现内网穿透 官网教程 1.安装花生壳 下载网址 点击复制就可以复制下载命令了 wget "https://dl.oray.com/hsk/linux/phddns_5.2.0_amd64.rpm" -O phddns_5.2.0_amd64.rpm# 下载完成之后会多一个rpm文件 [rootlocalhost HuaSheng]# ls phddns_…...

Jackson类层次结构中的一些应用(Inheritance with Jackson)

Have a look at working with class hierarchies in Jackson. 如何在Jackson中使用类层次结构。 Inclusion of Subtype Information There are two ways to add type information when serializing and deserializing data objects, namely global default typing and per-cl…...

Python求均值、方差、标准偏差SD、相对标准偏差RSD

均值 均值是统计学中最常用的统计量&#xff0c;用来表明资料中各观测值相对集中较多的中心位置。用于反映现象总体的一般水平&#xff0c;或分布的集中趋势。 import numpy as npa [2, 4, 6, 8]print(np.mean(a)) # 均值 print(np.average(a, weights[1, 2, 1, 1])) # 带…...

SQL ASNI where from group order 顺序

SQL语句执行顺序&#xff1a; from–>where–>group by -->having — >select --> order 第一步&#xff1a;from语句&#xff0c;选择要操作的表。 第二步&#xff1a;where语句&#xff0c;在from后的表中设置筛选条件&#xff0c;筛选出符合条件的记录。 …...

springboot(39) : RestTemplate完全体

HTTP请求调用集成,支持GET,POST,JSON,Header调用,日志打印,请求耗时计算,设置中文编码 1.使用(注入RestTemplateService) Autowiredprivate RestTemplateService restTemplateService; 2.RestTemplate配置类 import org.springframework.context.annotation.Bean; import org.…...

python中计算2的32次方减1,python怎么算2的3次方

大家好&#xff0c;给大家分享一下怎么样用python编写2的n次方,n由键盘输入&#xff0c;很多人还不知道这一点。下面详细解释一下。现在让我们来看看&#xff01; ---恢复内容开始--- 1、内置函数&#xff1a;取绝对值函数abs() 2、内置函数&#xff1a;取最大值max()&#xff…...

阿里云SLB负载均衡ALB、CLB和NLB有什么区别?

阿里云负载均衡SLB分为传统型负载均衡CLB&#xff08;原SLB&#xff09;、应用型负载均衡ALB和网络型负载均衡NLB&#xff0c;三者有什么区别&#xff1f;CLB是之前的传统的SLB&#xff0c;基于物理机架构的4层负载均衡&#xff1b;ALB是应用型负载均衡&#xff0c;7层负载均衡…...

SynergyNet(头部姿态估计 Head Pose Estimation)复现 demo测试

目录 0 相关资料1 环境搭建2 安装 SynergyNet3 下载相关文件4 编译5 测试 0 相关资料 SynergyNet&#xff08;github&#xff09;&#xff1a;https://github.com/choyingw/SynergyNet 1 环境搭建 我用的AutoDL平台搭建 选择镜像 PyTorch 1.9.0 Python 3.8(ubuntu18.04) Cu…...

mysql高级(尚硅谷-夏磊)

目录 内容介绍 Linux下MySQL的安装与使用 Mysql逻辑架构 Mysql存储引擎 Sql预热 索引简介 内容介绍 1、Linux下MySQL的安装与使用 2、逻辑架构 3、sql预热 Linux下MySQL的安装与使用 1、docker安装docker run -d \-p 3309:3306 \-v /atguigu/mysql/mysql8/conf:/etc/my…...

C++实用技术(二)std::function和bind绑定器

目录 简介std::functionstd::function对象包装器std::function做回调函数 std::bind绑定器bind绑定普通函数bind绑定成员函数 简介 C11新增了std::function和std::bind。用于函数的包装以及参数的绑定。可以替代一些函数指针&#xff0c;回调函数的场景。 std::function std…...

浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)

✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义&#xff08;Task Definition&…...

【JavaEE】-- HTTP

1. HTTP是什么&#xff1f; HTTP&#xff08;全称为"超文本传输协议"&#xff09;是一种应用非常广泛的应用层协议&#xff0c;HTTP是基于TCP协议的一种应用层协议。 应用层协议&#xff1a;是计算机网络协议栈中最高层的协议&#xff0c;它定义了运行在不同主机上…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...

pycharm 设置环境出错

pycharm 设置环境出错 pycharm 新建项目&#xff0c;设置虚拟环境&#xff0c;出错 pycharm 出错 Cannot open Local Failed to start [powershell.exe, -NoExit, -ExecutionPolicy, Bypass, -File, C:\Program Files\JetBrains\PyCharm 2024.1.3\plugins\terminal\shell-int…...

VisualXML全新升级 | 新增数据库编辑功能

VisualXML是一个功能强大的网络总线设计工具&#xff0c;专注于简化汽车电子系统中复杂的网络数据设计操作。它支持多种主流总线网络格式的数据编辑&#xff08;如DBC、LDF、ARXML、HEX等&#xff09;&#xff0c;并能够基于Excel表格的方式生成和转换多种数据库文件。由此&…...

StarRocks 全面向量化执行引擎深度解析

StarRocks 全面向量化执行引擎深度解析 StarRocks 的向量化执行引擎是其高性能的核心设计&#xff0c;相比传统行式处理引擎&#xff08;如MySQL&#xff09;&#xff0c;性能可提升 5-10倍。以下是分层拆解&#xff1a; 1. 向量化 vs 传统行式处理 维度行式处理向量化处理数…...

当下AI智能硬件方案浅谈

背景&#xff1a; 现在大模型出来以后&#xff0c;打破了常规的机械式的对话&#xff0c;人机对话变得更聪明一点。 对话用到的技术主要是实时音视频&#xff0c;简称为RTC。下游硬件厂商一般都不会去自己开发音视频技术&#xff0c;开发自己的大模型。商用方案多见为字节、百…...

react更新页面数据,操作页面,双向数据绑定

// 路由不是组件的直接跳转use client&#xff0c;useEffect&#xff0c;useRouter&#xff0c;需3个结合&#xff0c; use client表示客户端 use client; import { Button,Card, Space,Tag,Table,message,Input } from antd; import { useEffect,useState } from react; impor…...

生成对抗网络(GAN)损失函数解读

GAN损失函数的形式&#xff1a; 以下是对每个部分的解读&#xff1a; 1. ⁡, ​ &#xff1a;这个部分表示生成器&#xff08;Generator&#xff09;G的目标是最小化损失函数。 &#xff1a;判别器&#xff08;Discriminator&#xff09;D的目标是最大化损失函数。 GAN的训…...

Python打卡训练营学习记录Day49

知识点回顾&#xff1a; 通道注意力模块复习空间注意力模块CBAM的定义 作业&#xff1a;尝试对今天的模型检查参数数目&#xff0c;并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...