Qt【第七篇】 ——— QSS 样式表与绘图 API 核心用法及 UI 定制功能总结

news2026/4/7 2:35:24
目录QSSwidget.cppQSS的基本使用widget.cppQSS选择器的用法widget.cppQSS子控件选择器widget.cppQSS伪类选择器widget.cppQSS盒子模型QSS 基本格式与基础用法QSS 选择器分类及作用范围QSS 子控件选择器QSS 伪类选择器QSS 盒子模型绘图API的基本使用widget.cpp重写paintEvent事件函数widget.cpp画笔的使用widget.cpp画刷的使用paintEvent 绘图事件函数QPainter 画家类QPen 画笔类QBrush 画刷类QSSwidget.cppQSS的基本使用#include widget.h #include ui_widget.h Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { ui-setupUi(this); // Qt 样式表 QSS 基础用法 // QSS (Qt Style Sheets)Qt 提供的界面美化工具语法和 CSS 几乎一致 // 格式控件类型 { 样式属性: 属性值; } // 1. 为 第一个按钮 (pushButton) 设置样式 // 选择器QPushButton → 仅对当前按钮生效 // 样式color: red; → 设置按钮**文字颜色为红色**英文颜色名 ui-pushButton-setStyleSheet(QPushButton { color: red; }); // 2. 为 第二个按钮 (pushButton_2) 设置样式 // color: #ffaa00; → 设置文字颜色为**橙黄色**十六进制颜色码通用网页颜色格式 ui-pushButton_2-setStyleSheet(QPushButton { color: #ffaa00; }); // 3. 为**整个窗口**设置全局样式 // 选择器QLineEdit → 窗口内所有的输入框都生效 // 样式文字颜色为绿色 this-setStyleSheet(QLineEdit { color: green; }); } Widget::~Widget() { // 释放 UI 资源 delete ui; }widget.cppQSS选择器的用法#include widget.h // Qt应用程序核心类管理应用程序生命周期 #include QApplication int main(int argc, char *argv[]) { // 1. 创建Qt应用程序对象必须第一个创建 QApplication a(argc, argv); // 全局 QSS 样式表设置 // 给 QApplication 设置样式表 【整个应用全局生效】 // 注意多次调用 setStyleSheet**后面的会完全覆盖前面的** // 1. 类型选择器匹配所有 QPushButton 按钮控件 // 作用所有按钮文字颜色绿色 a.setStyleSheet(QPushButton { color: green; } ); // 2. 类型选择器匹配所有 Widget 窗口类 // 作用Widget 窗口内文字颜色绿色覆盖上一行 a.setStyleSheet(Widget { color: green; } ); // 3. 类选择器带点 .匹配 Widget 类及其子类 // 作用范围更广覆盖上一行 a.setStyleSheet(.Widget { color: green; } ); // 4. 对象名选择器#id精准匹配【对象名为 pushButton_2】的控件 // 作用仅该按钮文字蓝色字体大小70px覆盖上一行 a.setStyleSheet(#pushButton_2 { color: blue; font-size: 70px; } ); // 5. 分组选择器同时为多个控件设置相同样式 // 作用所有 QPushButton 所有 QLineEdit 文字绿色最终生效的样式 a.setStyleSheet(QPushButton, QLineEdit {color: green} ); // 创建主窗口对象 Widget w; // 显示窗口 w.show(); // 启动Qt事件循环程序运行 return a.exec(); }widget.cppQSS子控件选择器#include widget.h // Qt应用程序核心类负责程序启动、事件循环、全局样式管理 #include QApplication int main(int argc, char *argv[]) { // 创建Qt应用程序对象程序入口必须 QApplication a(argc, argv); // 定义QSS样式字符串 // 1. QComboBox::down-arrowQSS 子控件选择器 // :: 代表选中 QComboBox 的【下拉箭头子控件】 // 2. image: url(:/down.png);设置箭头的显示图片 // :/ 开头 Qt 资源文件路径必须将图片添加到 qrc 资源文件中 QString style QComboBox::down-arrow { image: url(:/down.png); } ; // 为【整个应用】设置全局样式表 // 所有界面中的 QComboBox 下拉箭头都会被替换为自定义图片 a.setStyleSheet(style); // 创建主窗口并显示 Widget w; w.show(); // 启动Qt事件循环程序运行 return a.exec(); }widget.cppQSS伪类选择器#include widget.h // Qt应用程序核心类管理全局样式、程序生命周期 #include QApplication int main(int argc, char *argv[]) { // 创建Qt应用程序对象程序入口必备 QApplication a(argc, argv); // 拼接全局QSS样式表 // 1. 定义基础样式QPushButton 默认状态 文字红色 QString style QPushButton { color: red; } ; // 2. 拼接悬浮样式:hover 伪状态 → 鼠标悬浮在按钮上时文字绿色 style QPushButton:hover { color: green; } ; // 3. 拼接按下样式:pressed 伪状态 → 鼠标按下按钮时文字蓝色 style QPushButton:pressed {color: blue; } ; // 为整个应用设置**全局样式表** // 程序中所有的 QPushButton 按钮都会生效这三种样式 a.setStyleSheet(style); // 创建主窗口并显示 Widget w; w.show(); // 启动Qt事件循环程序保持运行 return a.exec(); }widget.cppQSS盒子模型#include widget.h // Qt应用程序核心类用于设置全局样式、管理程序运行 #include QApplication int main(int argc, char *argv[]) { // 创建Qt应用程序对象程序入口必须 QApplication a(argc, argv); // QSS 边框 内边距样式 // 1. border: 10px solid green; // 边框复合属性一次性设置三个参数 // 10px → 边框宽度粗细 // solid → 边框样式实线可替换为 dashed虚线 // green → 边框颜色 // 2. padding-left: 30px; // 左内边距标签内部的文字/内容 距离 左边框的距离为30像素 // padding内边距可替换为 margin外边距控件与外部控件的距离 QString style QLabel { border: 10px solid green; padding-left: 30px; } ; // 为整个应用设置全局样式所有QLabel标签都会应用该样式 a.setStyleSheet(style); // 创建主窗口并显示 Widget w; w.show(); // 启动Qt事件循环程序运行 return a.exec(); }QSS 基本格式与基础用法QSS 基本格式固定语法为选择器 {属性名属性值}与 CSS 语法高度兼容是 Qt 界面美化的核心规则。单个控件样式设置调用控件自身的setStyleSheet方法样式仅对当前控件生效。// 仅对 pushButton 按钮生效文字颜色为红色 ui-pushButton-setStyleSheet(QPushButton { color: red; });窗口级样式设置调用窗口对象的setStyleSheet方法样式对当前窗口内所有匹配的子控件全局生效。// 当前窗口中所有 QLineEdit 输入框文字颜色均为绿色 this-setStyleSheet(QLineEdit { color: green; });QSS 选择器分类及作用范围QApplication 级样式设置调用a.setStyleSheet方法样式对整个应用程序内所有控件生效后续设置会覆盖之前的样式。类型选择器匹配指定类型的所有控件直接使用控件类名。// 应用内所有 QPushButton 按钮文字为绿色 a.setStyleSheet(QPushButton { color: green; });类选择器以.开头匹配指定类及其所有子类控件。// 匹配 Widget 类及其子类控件文字为绿色 a.setStyleSheet(.Widget { color: green; });对象名选择器以#开头精准匹配指定objectName的单个控件。// 仅匹配对象名为 pushButton_2 的控件文字为蓝色、字号70px a.setStyleSheet(#pushButton_2 { color: blue; font-size: 70px; });分组选择器多个选择器用,分隔为不同控件设置相同样式。// 应用内所有 QPushButton 和 QLineEdit 文字为绿色 a.setStyleSheet(QPushButton, QLineEdit {color: green} );QSS 子控件选择器子控件选择器语法使用::标识用于选中复合控件的内部子元素实现精细化样式定制。适用场景修改下拉框箭头、滚动条滑块、输入框图标等内置子控件样式。// 选中 QComboBox 的下拉箭头子控件替换为自定义图片 QString style QComboBox::down-arrow { image: url(:/down.png); } ; a.setStyleSheet(style);QSS 伪类选择器伪类选择器语法使用:标识匹配控件的交互状态实现动态样式切换。常用伪类:hover鼠标悬浮在控件上时生效:pressed鼠标按下控件时生效// 按钮默认文字红色悬浮绿色按下蓝色 QString style QPushButton { color: red; } ; style QPushButton:hover { color: green; } ; style QPushButton:pressed {color: blue; } ; a.setStyleSheet(style);QSS 盒子模型盒子模型核心属性用于控制控件的边框、内边距、外边距规范控件的布局与间距。border设置控件边框统一配置宽度、样式、颜色。padding内边距控件内容与边框之间的距离。margin外边距控件边框与外部其他控件之间的距离。// QLabel 边框10px 实线绿色左内边距30px QString style QLabel { border: 10px solid green; padding-left: 30px; } ; a.setStyleSheet(style);绘图API的基本使用widget.cpp重写paintEvent事件函数#include widget.h #include ui_widget.h // Qt 绘图核心类画家类负责绘制所有图形 #include QPainter Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { // 初始化UI界面 ui-setupUi(this); } Widget::~Widget() { // 释放UI资源 delete ui; } // 重写 绘图事件函数 // 作用窗口需要显示/刷新时自动调用该函数 // 所有自定义绘图代码都必须写在这个函数里 void Widget::paintEvent(QPaintEvent *event) { // 忽略未使用的 event 参数避免编译器警告 (void)event; // 1. 创建画家对象 // QPainterQt 绘图核心工具 // 参数 this指定绘图设备为【当前窗口】所有图形都画在本窗口上 QPainter painter(this); // 2. 绘制直线 // drawLine(x1, y1, x2, y2) // (x1,y1)直线起点坐标 (x2,y2)直线终点坐标 // 坐标原点窗口左上角 painter.drawLine(20, 20, 200, 20); // 水平直线 painter.drawLine(20, 20, 100, 300); // 斜直线 // 3. 绘制矩形 // drawRect(x, y, width, height) // (x,y)矩形左上角坐标 // width矩形宽度 height矩形高度 painter.drawRect(100, 100, 300, 300); // 4. 绘制椭圆 // drawEllipse(x, y, width, height) // 椭圆的外接矩形以 (x,y) 为左上角宽width、高height 的矩形 // 矩形内切椭圆 最终绘制的椭圆 // 宽高 → 圆形宽≠高 → 椭圆 painter.drawEllipse(200, 200, 200, 50); }widget.cpp画笔的使用#include widget.h #include ui_widget.h // Qt绘图核心类画家类 #include QPainter Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { // 初始化UI界面 ui-setupUi(this); } Widget::~Widget() { // 释放UI资源 delete ui; } // 重写绘图事件所有绘图逻辑必须写在这里 // 窗口刷新、显示时自动调用该函数 void Widget::paintEvent(QPaintEvent *event) { // 忽略未使用的参数消除编译器警告 (void)event; // 1. 创建画家对象指定在当前窗口(this)上绘图 QPainter painter(this); // 2. 创建并自定义画笔 QPen // QPen画笔负责控制**线条的颜色、粗细、样式** QPen pen; // 设置画笔颜色RGB(255,0,0) → 纯红色 pen.setColor(QColor(255, 0, 0)); // 设置画笔宽度5 像素线条粗细 pen.setWidth(5); // 设置画笔线条样式Qt::DashLine → 虚线 // 可选SolidLine(实线)、DotLine(点线)、DashDotLine(点划线)等 pen.setStyle(Qt::DashLine); // 3. 将自定义的画笔交给画家画家使用该画笔绘制图形 painter.setPen(pen); // 4. 绘制椭圆 // drawEllipse(x, y, width, height) // 椭圆的外接矩形左上角(200,200)宽200高50 painter.drawEllipse(200, 200, 200, 50); }widget.cpp画刷的使用#include widget.h #include ui_widget.h // Qt绘图核心类画家类负责绘制图形 #include QPainter Widget::Widget(QWidget parent) : QWidget(parent) , ui(new Ui::Widget) { // 初始化UI界面 ui-setupUi(this); } Widget::~Widget() { // 释放UI资源 delete ui; } // 重写绘图事件 // 窗口绘制/刷新时自动调用所有绘图逻辑必须写在此函数中 void Widget::paintEvent(QPaintEvent *event) { // 忽略未使用的事件参数消除编译器警告 (void)event; // 1. 创建画家对象指定绘图设备为当前窗口 QPainter painter(this); // 2. 创建并自定义画刷 QBrush // QBrush画刷专门用于填充【矩形、椭圆等封闭图形】的内部区域 QBrush brush; // 设置画刷颜色RGB(0,255,0) → 纯绿色 brush.setColor(QColor(0, 255, 0)); // 设置画刷填充样式Qt::SolidPattern → 实心填充最常用 brush.setStyle(Qt::SolidPattern); // 3. 将自定义画刷交给画家画家使用该画刷填充图形 painter.setBrush(brush); // 4. 绘制椭圆自动填充内部 // 椭圆是封闭图形会自动使用画刷填充内部 // 参数左上角x、左上角y、宽度、高度 painter.drawEllipse(200, 200, 200, 50); }paintEvent 绘图事件函数核心作用Qt 提供的绘图事件虚函数窗口显示、刷新、缩放、移动时自动触发所有自定义绘图逻辑必须编写在该函数内部。函数特性属于 QWidget 的内置虚函数自定义窗口类需重写实现绘图功能。// 重写绘图事件函数 void Widget::paintEvent(QPaintEvent *event) { (void)event; // 忽略未使用参数消除编译器警告 // 所有绘图代码 }QPainter 画家类核心定义Qt 绘图核心工具类统一执行图形绘制操作构造时指定绘图设备当前窗口。构造方式QPainter painter(this)this表示绘图目标为当前窗口坐标原点为窗口左上角。核心绘制函数及参数drawLine绘制直线参数为x1,y1起点坐标、x2,y2终点坐标。painter.drawLine(20, 20, 200, 20);drawRect绘制矩形参数为x,y左上角坐标、width宽度、height高度。painter.drawRect(100, 100, 300, 300);drawEllipse绘制椭圆 / 圆形参数为外接矩形的x,y、宽度、高度宽高相等时为圆形。painter.drawEllipse(200, 200, 200, 50);QPen 画笔类核心定义用于设置图形边框线条的样式控制线条的颜色、粗细、线型仅作用于图形轮廓。核心成员函数setColor设置画笔颜色支持QColor(R,G,B)格式赋值。setWidth设置画笔宽度单位为像素数值越大线条越粗。setStyle设置线条样式可选Qt::SolidLine实线、Qt::DashLine虚线等。setPen将自定义画笔绑定到画家对象生效绘图样式。QPen pen; pen.setColor(QColor(255, 0, 0)); // 设置红色 pen.setWidth(5); // 设置线条宽度5像素 pen.setStyle(Qt::DashLine); // 设置虚线样式 painter.setPen(pen); // 绑定画笔QBrush 画刷类核心定义用于封闭图形内部填充控制填充区域的颜色、填充样式仅作用于矩形、椭圆等封闭图形的内部。核心成员函数setColor设置画刷填充颜色。setStyle设置填充样式Qt::SolidPattern为实心填充最常用。setBrush将自定义画刷绑定到画家对象生效填充效果。QBrush brush; brush.setColor(QColor(0, 255, 0)); // 设置绿色填充 brush.setStyle(Qt::SolidPattern); // 设置实心填充 painter.setBrush(brush); // 绑定画刷

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2491106.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…