欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > [Qt] 控件 | QWidget | 窗口设置 | qrc | cursor | QSS

[Qt] 控件 | QWidget | 窗口设置 | qrc | cursor | QSS

2025/1/8 0:44:31 来源:https://blog.csdn.net/2301_80171004/article/details/144908242  浏览:    关键词:[Qt] 控件 | QWidget | 窗口设置 | qrc | cursor | QSS

目录

一、窗口标题(windowTitle)

二、窗口图标(windowIcon)

资源管理与路径使用

1、图片路径的选择

2、路径类型说明

3、构建目录的作用

qrc 文件的特点

qrc 的局限性

通过 qrc 管理图片作为图标

三、窗口透明度(windowOpacity)

四、光标属性(cursor)

五. 字体属性(QFont)

1. ToolTip 设置

API 说明

2. Focus Policy 设置

Qt::FocusPolicy 枚举类型

3. Style Sheet (QSS)

关于计算机中的颜色表示


接着上篇文章[Qt] 常用控件 | QWidget | “表白程序2.0”,我们来继续对控件 进行讲解~

一、窗口标题(windowTitle

  • API 概览

API

说明

windowTitle()

获取控件的窗口标题。

setWindowTitle(const QString& title)

设置控件的窗口标题。注意,仅对顶层 widget 有效,子 widget 上该操作无效。

  • 代码示例:设置窗口标题

执行效果:

二、窗口图标(windowIcon

  • API 概览

API

说明

windowIcon()

获取控件的窗口图标,返回 QIcon 对象。

setWindowIcon(const QIcon& icon)

设置控件的窗口图标。同 windowTitle,仅对顶层 widget 有效。

同 windowTitle,上述操作仅针对顶层 widget 有效。


(1)设置窗口图标

A. 先在 D 盘中保存一张图片,我这里命名为 qt_star.jpg

B. 修改 widget.cpp

  • 前面推荐使用堆来创建对象,主要是因为要确保当前控件的生命周期是足够的,要通过 Qt 对象树来释放对象。
  • QIcon 自身是一个比较小的对象。创建出来之后,就是要设置到某个 QWidget 里面,QIcon 对象本身是否释放并不影响图标最终的显示。
  • QIcon 也不支持对象树,无法给它执行父对象。

注意

  • Windows 下路径的分隔符可以使用 / 也可以使用 \
  • 但是如果在字符串中使用 \,需要写作转义字符的形式 \\
  • 因此还是更推荐使用 /。

同时,程序在任务栏中的图标也发生改变:

资源管理与路径使用
1、图片路径的选择
  • 避免绝对路径:实际开发中,通常不会在代码中通过绝对路径引入图片。因为无法保证程序发布后,用户的电脑上也有同样的路径。
  • 相对路径的要求:如果选择使用相对路径,则需要确保代码中的相对路径写法和图片实际所在的路径匹配。例如,代码中写作 "./image/Q&A.jpg",就需要在当前工作目录中创建 image 目录,并把 Q&A.jpg 放进去。
2、路径类型说明
  • 绝对路径:以盘符(Windows)或者以 /(Linux)开头的路径。
  • 相对路径.(表示当前路径)或者以 ..(表示当前路径上级路径)开头的路径。其中 . 经常也会省略。使用相对路径的前提是明确“当前工作目录”。

对于 Qt 程序来说,当前工作目录可能是变化的:

  • 通过 Qt Creator 运行的程序,当前工作目录是项目的构建目录。
  • 直接双击 exe 运行时,工作目录则是 exe 所在目录
3、构建目录的作用

所谓构建目录,是和 Qt 项目并列的,专门用来放生成的临时文件和最终 exe 的目录

Qt 使用 qrc 机制 来自动管理项目依赖的静态资源,解决了以下两个关键问题:

  1. 确保我们的图片所在路径在目标用户机器上存在。
  2. 确保我们的图片不会被用户误删或修改。

qrc 文件的特点
  • qrc 文件是一种 XML 格式的资源配置文件
  • 用 XML 记录硬盘上的文件和对应的随意指定的资源名称,应用程序通过资源名称来访问这些资源
  • 在 Qt 开发中,可以通过将资源文件添加到项目中来方便地访问和管理这些资源,这些资源文件可以位于 qrc 文件所在目录的同级或其子目录下。
  • 在构建程序的过程中,Qt 会把资源文件的二进制数据转成 cpp 代码,编译到 exe 中,从而使依赖的资源变得 “路径无关”。

这种资源管理机制并非 Qt 独有,很多开发框架都有类似的机制。例如 Android 的 Resources 和 AssetManager 也提供了类似的功能。

qrc 的局限性
  • 不适合大文件qrc 不适合导入太大的资源文件,因为这会导致最终 exe 文件体积增大,程序运行内存消耗增加及编译时间显著增长。
通过 qrc 管理图片作为图标

(1)右键项目,创建一个 Qt Resource File(qrc 文件)

文件名随意起(不要带中文和特殊符号即可),这里叫做:resource.qrc

(2)在 qrc 编辑器中添加前缀

此处我们前缀设置成 / 即可。

所谓的前缀,可以理解成 “虚拟的目录”,这个目录在我们的电脑中并不是真实存在的,是 Qt 自己抽象出来的,它决定了后续我们如何在代码中访问资源。


(3)在资源编辑器中,点击 add Files 添加资源文件

此处我们需要添加的是:qt_star.jpg:

注意

  • 添加的文件必须是在 qrc 文件的同级目录或者同级目录的子目录中
  • 因此我们需要把之前 D 盘中的 .jpg 复制到上述目录中。

添加完毕后,可以在资源编辑器中看到添加好的文件:

(4)在代码中使用 qt_star.jpg

A. 编辑 widget.cpp

代码中需要访问 qrc 中管理的文件时,就需要在路径上带有 : 前缀。创建的前缀叫什么名字,代码中就写什么名字:前缀 + 文件名。

注意上述路径的访问规则:

  • 使用 : 作为开头,表示从 qrc 中读取资源
  • / 是上面配置的前缀
  • qt_star.jpg 是资源的名称

需要确保代码中编写的路径 和添加到 qrc 中资源的路径匹配,否则资源无法被访问(同时也不会有报错提示)。


运行成功后,我们可以进入到项目的构建目录中可以看到:目录中多了一个 qrc_resource.cpp 文件,直接打开这个文件可以看到:

qrc 中导入的图片资源会被转成这个 qrc_resource.cpp(自动生成)这个 c++ 代码:

查看

上述代码其实就是通过 unsigned char 数组,把 qt_star.jpg 中的每个字节都记录下来。

这些代码会被编译到 exe 中,后续无论 exe 被复制到哪个目录下都确保能够访问到该图片资源。

上述 qrc 这一套资源管理方案的优点和缺点都很明显:

  • 优点:确保了图片、字体、剩余等资源能够真正做到 “目录无关”,无论如何都不会出现资源丢失的情况。
  • 缺点不适合管理体积大的资源。如果资源比较大(比如是几个 MB 的文件),或者资源特别多,生成的最终的 exe 体积就会比较大,程序运行消耗的内存也会增大,程序编译的时间也会显著增加。

三、窗口透明度(windowOpacity

  • API 概览

API

说明

windowOpacity()

获取控件的不透明数值,取值范围为 0.0(全透明)到 1.0(完全不透明)。

setWindowOpacity(float n)

设置控件的不透明数值。

调整窗口透明度

(1)在界面上拖放两个按钮,分别用来增加不透明度和减少不透明度

objectName 分别为 pushButton_add pushButton_sub

(2)编写 wdiget.cpp, 编写两个按钮的 slot 函数

  • 点击 pushButton_sub 会减少不透明度,也就是窗口越来越透明
  • 点击 pushButton_add 会增加不透明度,窗口会逐渐恢复

(3)执行程序

点击了几下 '-' 之后,就可以透过窗⼝看到后面的内容了,点击 '+' 又会逐渐恢复:

同时控制台中也可以看到 opacity 数值的变化

注意

  • C++ 中 float 类型遵守 IEEE 754 标准,因此在进行运算的时候会有一定的精度误差
  • 因此 1 - 0.1 的数值并非是 0.9。

关于 浮点数的 存储 之前有讲到过~18.(C进阶)数据在内存中的存储


四、光标属性(cursor

  • API 概览

API

说明

cursor()

获取当前 widget 的光标属性,返回 QCursor 对象。

setCursor(const QCursor& cursor)

设置该 widget 的光标形状,仅在鼠标停留在该 widget 上时生效。

QGuiApplication::setOverrideCursor(const QCursor& cursor)

设置全局光标的形状,覆盖 setCursor 设置的内容。

在 Qt Designer 中设置按钮的光标

(1)在界面中创建一个按钮

(2)直接在右侧属性编辑区修改 cursor 属性为 “打开手势”

(3)运行程序

鼠标悬停到按钮上,即可看到光标的变化。


通过代码设置按钮的光标

(1) 编写 widget.cpp

其中 Qt::WaitCursor 就是自带的沙漏 / 转圈形状的光标。

系统内置的光标形状如下:

Ctrl + 左键点击 Qt::WaitCursor 跳转到源码即可看到:


自定义鼠标光标

Qt 自带的光标形状有限,我们也可以自己找个图片,做成鼠标的光标。比如 537~

(1)创建 qrc 资源文件,添加前缀 /,并加入图片

(2)编写 widget.cpp

上面路径 应该是 /prc/537.png


五. 字体属性(QFont

字体属性是界面设计中重要的组成部分,它们影响着文本的外观。Qt 提供了多种方式来设置和获取字体属性。

API 说明

  • font():用于 获取 当前 widget 的字体信息。返回一个 QFont 对象。
  • setFont(const QFont& font):用于 设置 当前 widget 的字体信息。

属性列表

属性

说明

family

字体家族,例如 "楷体", "宋体", "微软雅黑" 等。

pointSize

字体大小。

weight

字体粗细,以数值表示粗细程度,取值范围为 [0, 99],数值越大,越粗。

bold

是否加粗,设置为 true 相当于 weight 为 75;false 则为 50。

italic

是否倾斜。

underline

是否带有下划线。

strikeOut

是否带有删除线。


在 Qt Designer 中设置字体属性

(1)在界面上创建一个 label

2)在右侧的属性编辑区,设置该 label 的 font 相关属性

在这里调整上述属性,可以实时的看到文字的变化。

(3)执行程序


在代码中设置字体属性

(1)编写 widget.cpp

(2)运行程序

  • 在实际开发中,字体属性如何选择是一个 “审美问题”,而不是 “技术问题”,往往需要有一定的艺术细胞。
  • 幸运的是,公司中 往往有专业的 “美工” / “设计” 这样的岗位,去做这方面的工作,我们程序员只要按照人家给的设计稿,把代码写出来即可,不必过多考虑怎样搭配才好看的问题。

1. ToolTip 设置

Tooltip 是用户 悬停在 widget 上时显示的提示信息,有助于提高用户体验。

API 说明
  • setToolTip(const QString &tooltip):设置 tooltip 文本。
  • setToolTipDuration(int msec):设置 tooltip 显示的 时间,单位为毫秒。

设置按钮的 toolTip

(1)在界面上拖放两个按钮:objectName 设置为 pushButton_yes 和 pushButton_no

(2)编写 widget.cpp

(3)运行程序

观察效果,可以看到鼠标停到按钮上之后,就能弹出提示,时间到后自行消失。


2. Focus Policy 设置

Focus policy 决定了控件是否及如何接收 键盘焦点。

设置控件获取到焦点的策略,比如某个控件 能否用鼠标选中 或者能否 通过 tab 键选中

  • 所谓 “焦点”,指的就是能选中这个元素。接下来的操作(比如键盘操作),就都是针对该焦点元素进行的了。这个对于输入框、单选框、复选框等控件非常有用的。
  • 这个事情就和 war3 或者 sc2 中,先选中单位,再下达命令是一样的。

API 说明

  • focusPolicy():获取当前 widget 的 focus policy。
  • setFocusPolicy(Qt::FocusPolicy policy)设置 widget 的 focus policy。
Qt::FocusPolicy 枚举 类型
  • Qt::NoFocus:控件不会接收键盘焦点。
  • Qt::TabFocus:控件可以通过 Tab 键接收焦点。
  • Qt::ClickFocus:控件在鼠标点击时接收焦点。
  • Qt::StrongFocus:默认值,控件可以通过 Tab 键和鼠标点击接收焦点。
  • Qt::WheelFocus:类似于 Qt::StrongFocus,同时控件也通过鼠标滚轮获取到焦点。

理解不同的 focusPolicy

(1)在界面上创建四个单行输入框(Line Edit)

(2)修改四个输入框的 focusPolicy 属性为 Qt::StrongFocus(默认取值,一般不用额外修改)

  • 此时运行程序可以看到,使用鼠标单击 / tab,就可以移动光标所在输入框,从而接下来的输入就是针对这个获取焦点的输⼊框展开的了。

(3)修改第二个输入框的 focusPolicy 为 Qt::NoFocus,则第二个输入框不会被 tab / 鼠标左键选中

  • 此时这个输入框也就无法输入内容了

(4)修改第二个输入框 focusPolicy 为 Qt::TabFocus,则只能通过 tab 选中,无法通过鼠标选中

(5)修改第二个输入框 focusPolicy 为 Qt::ClickFocus,则只能通过鼠标选中,无法通过 tab 选中


3. Style Sheet (QSS)

CSS(Cascading Style Sheets 层叠样式表)本身属于网页前端技术,主要用于 描述界面的样式。

  • 所谓“样式”,包括但不限于大小、位置、颜色、间距、字体、背景、边框等。我们日常看到的丰富多彩的网页都会用到大量的 CSS。
  • 尽管 Qt 主要用于 GUI 开发,但它与网页前端有着许多相似之处。
  • 因此,Qt 引入了对 CSS 的支持,允许开发者使用类似的样式规则来定义 widgets 的外观。

然而,Qt 只能支持部分 CSS 样式属性,这些被支持的属性称为 QSS(Qt Style Sheet)。具体的支持情况可以参考 Qt 文档中的 "Qt Style Sheets Reference" 章节。

设置文本样式

(1)在界面上创建 label

(2)编辑右侧的 styleSheet 属性,设置样式

或者选择下面这种方式打开:

  • 此处的语法格式同 CSS,使用键值对的方式设置样式。其中键和值之间使用 : 分割;键值对之间使用 ; 分割。
  • 注意:Qt Designer 只能对样式的基本格式进行校验,不能检测出哪些样式不被 Qt 支持,例如 text-align: center 这样的文本居中操作,在某些情况下可能无法支持。

编辑完成样式之后,可以看到在 Qt Designer 中能够实时预览出效果:

(3)运⾏程序

可以看到实际效果和预览效果基本一致:


实现切换夜间模式

  • 日间模式:文字是黑色的,背景是白色的。
  • 夜间模式:文字是白色的,背景是黑色的。

(1)在界面上创建一个多行输入框(Text Edit)和两个按钮:objectName 分别为 pushButton_light 和 pushButton_dark

(2)编写按钮的 slot 函数

  • #333 是深色,但不是完全黑色。
  • #fff 是纯白色。
  • #000 是纯黑色。

使用在线调色板或画图板工具可以查看颜色对应的数值。

例如,在线调色板,调色板工具—在线工具 (sojson.com)。

关于计算机中的颜色表示
  • 计算机中使用“像素”表示屏幕上的一个基本单位(即一个发光点)。每个像素都使用三个字节表示颜色,分别是 R(red)、G(green)、B(blue),每个字节取值范围是 0-255 或者 0x00-0xFF。

混合三种不同颜色的数值比例可以搭配出千千万万的颜色出来。

  • rgb(255, 0, 0) 或者 #FF0000 或者 #F00 表示纯红色。
  • rgb(0, 255, 0) 或者 #00FF00 或者 #0F0 表示纯绿色。
  • rgb(0, 0, 255) 或者 #0000FF 或者 #00F 表示纯蓝色。
  • rgb(255, 255, 255) 或者 #FFFFFF 或者 #FFF 表示纯白色。
  • rgb(0, 0, 0) 或者 #000000 或者 #000 表示纯黑色。

上述规则适用于一般程序的颜色设定。

实际显示器可能会有8bit 色深或者 10bit 色深等,具体情况会更加复杂。

运行程序

  • 点击“日间模式”按钮,界面将显示浅色背景和深色文字。
  • 点击“夜间模式”按钮,界面将显示深色背景和浅色文字。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com