Qt的Qss用法小结

 更新时间:2023年06月06日 10:00:04   作者:IT观察者  
Qt的Qss是一种用于定义用户界面的样式表语言,本文主要介绍了Qt的Qss用法小结,非常具有实用价值,需要的朋友可以参考下

Qt 的 Qss 是一种用于定义用户界面的样式表语言。它可以用来定义控件的颜色、字体、边框、背景等样式,可以很方便的实现自定义的样式效果。

Qss 的基本语法和 CSS 类似,主要是由选择器和样式属性构成。

选择器

选择器用来指定要样式化的控件,选择器可以使用控件的名称、类型、ID、类、父子关系等来进行定位。常见的选择器有:

  • 类型选择器: QPushButton
  • 类选择器: .mybutton
  • ID 选择器: #mybutton
  • 属性选择器: QWidget[enabled="false"]
  • 父子选择器: QListWidget > QListWidgetItem

样式属性

在 Qt 的 Qss 中,样式属性可以分为两类:控件属性和子控件属性,其中控件属性用于设置控件自身的样式,子控件属性用于设置控件的子控件的样式。

常用的控件属性和样式如下:

样式属性描述
background控件背景色
border控件边框
color控件文本颜色
font-size控件字体大小
font-family控件字体
padding内边距
margin外边距
text-align控件文本对齐方式
text-indent控件文本缩进
opacity控件透明度

常用的子控件属性和样式如下:

样式属性描述
QScrollBar:vertical竖向滚动条
QScrollBar:horizontal横向滚动条
QScrollBar::handle滚动条滑块
QScrollBar::add-page滚动条向后翻页按钮
QScrollBar::sub-page滚动条向前翻页按钮
QScrollBar::add-line滚动条向后滚动按钮(小箭头)
QScrollBar::sub-line滚动条向前滚动按钮(小箭头)
QComboBox QAbstractItemView下拉框的列表视图
QComboBox QAbstractItemView::item下拉框的列表项

示例

下面是一个简单的 Qss 样式示例:

QPushButton {
  background: #00bfff;
  color: #fff;
  border: 2px solid #fff;
  font-size: 24px;
  padding: 4px 8px;
  margin: 4px;
}
QLineEdit {
  background: #fff;
  color: #000;
  border: 2px solid #00bfff;
  padding: 4px 8px;
  margin: 4px;
}
QComboBox QAbstractItemView {
  background: #fff;
  color: #000;
  border: 2px solid #00bfff;
  padding: 4px 8px;
  margin: 4px;
}
QComboBox QAbstractItemView::item {
  background: #00bfff;
  color: #fff;
  font-size: 18px;
  padding: 4px 8px;
  margin: 4px;
}
QScrollBar:vertical {
  background: #fff;
  width: 16px;
  margin: 4px;
}
QScrollBar::handle:vertical {
  background: #00bfff;
  border-radius: 8px;
  margin: 2px;
}
QScrollBar::add-page:vertical, QScrollBar::sub-page:vertical {
  background: none;
}
QScrollBar:horizontal {
  background: #fff;
  height: 16px;
  margin: 4px;
}
QScrollBar::handle:horizontal {
  background: #00bfff;
  border-radius: 8px;
  margin: 2px;
}
QScrollBar::add-page:horizontal, QScrollBar::sub-page:horizontal {
  background: none;
}

上面的样式将会应用到 QPushButton、QLineEdit、QComboBox、QScrollBar 等控件上,并且可以看到各个控件的样式都是不一样的。其中,QComboBox 还设置了下拉列表视图及列表项的样式。

除了上述基本语法外,Qt 的 Qss 还有一些高级特性。

伪状态和伪元素

Qss 支持控件的伪状态和伪元素,用来描述控件处于特定状态时的样式。常见的状态包括:hover(鼠标悬停时)、pressed(鼠标按下时)、checked(选中状态)、disabled(不可用状态)等。

样式示例:

QPushButton:hover {
  background: #1e90ff;
}
QPushButton:checked {
  color: #ff4500;
}

尺寸和单位

Qss 支持不同的尺寸和单位来定义样式,包括像素(px)、绝对长度(cm、mm、in、pt、pc)、相对长度(em、ex、rem)、百分比(%)等,用于实现不同尺寸的控件效果。

QPushButton {
  width: 100px;
  height: 30px;
}
QLabel {
  font-size: 1.5em;
}
QTextEdit {
  padding: 0.5rem;
}
QComboBox {
  width: 50%;
}

颜色和图像

Qss 支持使用颜色和图像来定义控件的背景,边框和文本颜色等样式。

颜色示例:

QWidget {
  background-color: red;
}
QPushButton {
  color: white;
  background-color: rgb(0, 255, 0);
}
QLineEdit {
  border: 1px solid #ccc;
}
QLabel {
  color: black;
  background-color: rgba(255, 255, 0, 0.5);
}

图像示例:

QPushButton {
  border-image: url(button.png) 5 5 5 5 stretch;
}
QLabel {
  background-image: url(background.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
QTextEdit {
  background-image: url(paper.jpg);
  background-attachment: fixed;
}

动画效果

Qss 还支持使用动画效果来实现控件的动态样式,通过 @keyframes 和 animation 实现。

样式示例:

QPushButton:hover {
  animation: pulse 0.5s;
}
@keyframes pulse {
  0% {background-color: #1e90ff;}
  50% {background-color: #00bfff;}
  100% {background-color: #1e90ff;}
}

总结

到此这篇关于Qt的Qss用法小结的文章就介绍到这了,更多相关Qt Qss内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • c++ 入门——浅析构造函数和析构函数

    c++ 入门——浅析构造函数和析构函数

    这篇文章主要介绍了c++ 浅析构造函数和析构函数的相关资料,帮助大家入门c++ 编程,感兴趣的朋友可以了解下
    2020-08-08
  • C++基础学习之利用两个栈实现一个队列

    C++基础学习之利用两个栈实现一个队列

    这篇文章主要给大家介绍了关于C++基础学习之利用两个栈实现一个队列的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • C++ protobuf中对不同消息内容进行赋值的方式总结(set_、set_allocated_、mutable_、add_)

    C++ protobuf中对不同消息内容进行赋值的方式总结(set_、set_allocated_、mutable_、

    这篇文章主要给大家介绍了关于C++ protobuf中对不同消息内容进行赋值的方式总结,主要使用的是set_、set_allocated_、mutable_、add_,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • 一元多项式加法运算

    一元多项式加法运算

    今天小编就为大家分享一篇关于一元多项式加法运算,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • C语言实现数据的压缩与解压

    C语言实现数据的压缩与解压

    数据压缩是通过一系列的算法和技术将原始数据转换为更紧凑的表示形式,以减少数据占用的存储空间,数据解压缩则是将压缩后的数据恢复到原始的表示形式,本文给大家详细介绍了C语言实现数据压缩与解压,需要的朋友可以参考下
    2023-08-08
  • Qt模仿Windows文件夹缩略图的三种实现方式

    Qt模仿Windows文件夹缩略图的三种实现方式

    本文讲的不是简单的model/view或者widget的或者QML的基础框架实现,而是在这些框架之上的肉(文件夹缩略图)的效果实现,本文将以QWidget、Qt Quick(QML)、以及QGraph三种实现方式来讲解,如何做出和Windows类似的缩略图,需要的朋友可以参考下
    2024-04-04
  • C/C++中关于std::string的compare陷阱示例详解

    C/C++中关于std::string的compare陷阱示例详解

    这篇文章主要给大家介绍了关于C/C++中关于std::string的compare陷阱的相关资料,文中先对C/C++中的std::string进行了简单的介绍,通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-11-11
  • C++判断pe文件实例

    C++判断pe文件实例

    这篇文章主要介绍了C++判断pe文件的方法,包含了文件操作的具体实现方法,具有很好的参考借鉴价值,需要的朋友可以参考下
    2014-10-10
  • 浅谈c++中的异常处理机制

    浅谈c++中的异常处理机制

    C++异常处理机制通过try/catch/throw结构处理运行时错误,本文就来介绍一下c++中的异常处理机制,具有一定的参考价值,感兴趣的可以了解一下
    2025-02-02
  • C++应用实现简易五子棋游戏

    C++应用实现简易五子棋游戏

    这篇文章主要为大家详细介绍了C++应用实现简易五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05

最新评论