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

Qt --- 界面优化 --- QSS和绘图API

界面优化 =》美化

一个程序的界面是否好看,是否重要呢。

有些面向专业领域的程序,界面好看与否,不是看关键,更关键的是实际的效果。有些面向普通用户领域的程序,界面好看,还是很大的加分项。

界面优化 Qt中使用QSS =》网页前端 CSS

能够针对界面的样式来进行设置。包括不限于:大小、位置、颜色、背景、间距、字体……

CSS的功能是非常强大,非常丰富的。QSS要逊色一些,也能完成很多的工作。有时候,可以通过QSS设置样式。也可以通过C++代码设置样式。如果两者冲突,QSS优先级最好

基本语法:

选择器:先选择某个/某一类控件,接下来进行各种属性设置,都是针对选中的控件生效的。

键值对:针对某些样式具体的设置了。

上述代码的含义是把QPushButton按钮的文本设置成为红色。

一、QSS基础使用

代码:

设置样式的时候,是可以指定某个控件来设置的。指定控件之后,此时的样式就会针对这个指定的控件,也会针对子空间生效。

既要考虑到子空间,也要考虑到选择器的筛选。

设置全局样式

界面上所有的样式都集中到一起来组织。

如果设置了全局样式,然后在某个控件里有设置了其他样式,会怎么样。

此时这两方面的样式,会叠加起来。这叫做层叠性。

如果设置了全局样式,在某个控件里设置的样式和全局样式冲突了,又会怎么样。

局部样式的优先级是更高的,覆盖了对应的全局样式。

实际开发中,就可以在全局样式中设置比较通用的样式,统一整个程序的界面风格。如果需要针对某个控件进行微调,可以使用局部样式来做出调整。

二、样式和代码的分离

QSS上述代码中,样式代码和C++代码都是混在一起的。如果QSS样式代码比较简单,无所谓了,如果QSS代码非常复杂,继续这样搞,代码的维护成本就很高了。

我们可以把样式代码拎出来,放到单独的文件中,后续可以直接让C++代码来读取并加载文件内容。就可以解耦合了。

代码:

1、创建qrc文件,通过qrc管理样式文件。

2、创建单独的QSS文件,把这样的文件放到qrc中。

3、编写C++代码,读取QSS文件中的内容,并设置样式。

这个方案仅供参考,实际开发中还有更方便的方案。

在 Qt Designer中直接集成了这样的功能,允许我们把样式直接写到.ui文件里。

通过这里就可以编写界面的样式了,这里进行的修改都会记录到ui文件中,并且在程序运行时会自动生效。而且这里还能进行预览。

记录了当前编辑的样式,后续Qt根据ui文件生成C++代码,也就会同时把样式设置进去。

选中控件也是可以进行设置样式的。

由于设置样式太灵活,有很多地方都能设置,就导致当某个控件样式不符合预期的时候,排查起来就比较麻烦了。全局样式,指定控件的样式,指定控件的父控件的样式,QSS文件中的样式,ui文件中的样式。实际开发中,如果需要设置样式,建议最好统一使用某一种方式来设置。

三、选择器

类型选择器,类选择器。全局选择器

代码:

类型选择器对子类会生效,相同的类都会被选中

类选择器不会对子类生效。

在开发中,期望不同的控件样式不同,此时就需要使用id选择器了。id是唯一的。

当类选择器和id选择器选中同一个控件的时候,并且设置的样式是冲突的,此时id选择器的优先级更高。

并集选择器:也可以写成ID选择器

子控件选择器

含有子控件的控件:QSpinBox,QComboBox下拉框。

代码:

伪类选择器

前面介绍的选择器,都是选中控件,伪类选择器,选中的是控件的状态。符合一定状态条件的控件。

以上选择器还可以通过!取反。

代码:

这些功能也可以通过事件来书写。

四、盒子模型

box model盒子模型,来自于CSS

符合属性 margin可以拆成四个属性,margin-left,margin-right,margin-top,margin-bottom。

padding也是可以拆分成四个属性的。

代码:

 给按钮设置样式

给复选框设置样式

给输入框设置样式

给列表框设置样式

渐变色的使用方法

给菜单设置样式

实现登录界面

直观想法,是直接给QWidget顶层窗口设置背景图。但是Qt中存在限制,直接给顶层窗口设置背景会失效。暂时不知道为什么要这样。没有具体的解释。可以给上述控件外头套上一个和窗口大小一样大QFrame控件。

QSS小结

1、QSS是什么

2、QSS基本用法

3、选择器的使用

4、子控件选择器

5、伪类选择器

6、盒子模型

7、代码例子。QSS支持的样式属性值是很多的。

五、绘图API

绘图画画,前面学习Qt主要是学Qt的各种控件 =》本质上都是画出来的。都是一些常用的东西,Qt已经提前画好了,拿过来就能使用。实际开发中,很可能现有的控件无法满足要求,就需要自己diy一些控件,Qt提供的绘图API就是为了解决上述问题的。实际开发中大部分情况下不需要使用绘图API,

绘图API核心类

QPainter,提供一系列的绘图方法,实现会话的动作

QPaintDevice,你要画的内容是往啥东西上画的,也就是画板。QWidget就是QPaintDevice的子类。

QPen 画笔 。设置画图的线条属性。

QBrush 画刷 设置画图的填充属性。

一个关键的注意事项,画图相关的操作,一般不会放到QWidget的构造函数中调用执行,而是Qt提供了一个paintEvent事件处理函数,在这里进行调用。和paintEvent和它的对应的会有一个QPaintEvent事件,

1、控件首次创建的时候,比如往QWidget上画画,QWidget创建之前,画的东西当然不生效。首次创建QWidget就能显示出画的东西来。

2、控件被遮挡,在解除遮挡。这个时机进行绘制也是很重要的,否则绘制的内容就会被遮挡之后就没了。

3、窗口被最小化,再还原。

4、控件大小发生改变的时候

5、主动在代码中调用repaint或者update触发事件(都是QWidget提供的成员函数)。

绘制各种形状

绘制文字

0横坐标,表示的是文字最左侧的位置。

100纵坐标,表示的是文字的基线位置

通过画笔对象QPen设置绘制的形状的颜色信息

QBrush画刷

设置颜色和风格

可以设置的风格

具体的使用

绘制图片

QPixmap通过这个类,就可以表示一个图片。

图片的旋转

QPainter对象进行了旋转,绘制出来的内容也就产生了旋转了。

是绕着0,0坐标系原点进行了旋转。为了让图片显示出来,可以把坐标系原点(Painter的起点)平移一下。比如可以平移到窗口右下角。

Qt就告一段落了!祝我们可以找到心仪的工作。在计算机的道路上走得更远。


http://www.kler.cn/a/330164.html

相关文章:

  • CT重建笔记(二)
  • 深度剖析RabbitMQ:从基础组件到管理页面详解
  • 如何在 Linux、MacOS 以及 Windows 中打开控制面板
  • 2025年中科院分区大类划分公布!新增8155本
  • 2025宝塔API一键建站系统PHP源码
  • 如何在Jupyter中快速切换Anaconda里不同的虚拟环境
  • ML 系列: (10)— ML 中的不同类型的学习
  • 【rCore OS 开源操作系统】Rust 练习题题解: Enums
  • Nacos 是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台,旨在帮助开发者更轻松地构建、部署和管理微服务应用。
  • python单例和工厂模式
  • OpenCV库 详细常见操作
  • Lumerical脚本语言-系统(System)
  • RAG(检索增强生成)新探索:IdentityRAG 提高 RAG 准确性
  • springboot儿童物品共享平台的设计与实现
  • VMware Aria Suite Lifecycle 8.18 发布,新增功能概览
  • Go基础学习10-原子并发包sync.atomic的使用:CSA、Swap、atomic.Value......
  • 基于单片机的两轮直立平衡车的设计
  • 经验笔记:JavaScript 中的对象
  • 阿里云部署1Panel(失败版)
  • setState是同步更新还是异步更新
  • 基于Python的人工智能应用案例系列(18):SpaCy简历信息抽取
  • 旅游避坑指南
  • 基础岛第6关:OpenCompass 评测 InternLM-1.8B 实践
  • 深入了解 Ne10:优化 ARM 处理器的数字信号处理库
  • [C++][第三方库][gflags]详细讲解
  • Vue项目开发注意事项