QSS知识总结

QT样式表单

QT的样式表单允许我们在对程序不做任何代码上的更改的情况下轻松改变应用程序的外观。

其思想来源于网页设计中的CSS,即可以将功能设计和美学设计分开。

它的语法和概念和HTML CSS也是差不多的。

其原理可简单理解为:QT内部存在一个CSS语法解析器,我们将我们的样式控制以CSS语法定义到外部文件,CSS语法解析器解析后在调用相应的功能模块以完成样式变化。(其实这部分功能我们完全可以通过代码实现,只是这么做既麻烦而且一旦更改会很不方便)

比如:我在CSS定义字体颜色和大小,那么CSS语法解析器解读出我的意图后,可能就会调用freetype模块来实现此功能。

好处:1.将功能设计和美学设计分开

2.CSS设计资源多,查找容易

说明:QT Style 样式语法虽然和CSS语法差不多,但是其功能是其子集,在使用QT style时需具备CSS语法知识

 

CSS语法学习:http://www.w3school.com.cn/h.asp

CSS 参考手册:http://www.w3school.com.cn/cssref/index.asp

基本语法

1.      样式表单由一系列样式规则组成。每条规则可以分成两部分:选择器和声明

选择器表示规则作用到哪些控件上;声明则详细说明了是什么规则。

2.      Qt的样式表语法不区分大小写,所以color,Color,coLor,coloR都表示同样的颜色属性。但是指代类的类名的时候,是区分大小写的。

3.      多个选择器可以并列使用,它们之间用逗号隔开,例如:

QPushButton,QLineEdit, QComboBox{ color: red }

4.      声明部分也可以有多个并列,之间用分号隔开。当我们要设置的选择器有多个属性的时候,就需要并列多个声明,例如:

QPushButton{ color: red; background-color: white }

这条样式规则让按钮的字体变成红色,同时背景色变成白色。

选择器类别

Qt样式表单支持所有在CSS2中定义的选择器类型,下面介绍几种最为常用的选择器定义。


全局选择器


*


选中所有的Widget


特定类型选择器


QPushButton


选中所有QPushButton以及它派生出来的子类的对象


属性选择器


QPushButton[flat="false"]


选中所有flat属性为false的按钮

属性选择器

可用于QT中所有具有toString方法的属性,例如QPushButton的text、checked等属性。

当属性是一个QStringList时,可以用~=这个符号来匹配其中的某一项。

因为属性往往是动态的,当属性更改了的时候,需要调整样式表,通常做法是删除样式表,再重新加载

选择器类别


类选择器


QPushButton


选中所有QPushButton的对象,但不包括其子类


ID选择器


QPushButton#okButton


选中所有object name是okButton的QPushButton对象


子控件选择器


QDialog QPushButton


选中Qdialog上的所有QPushButton子控件(直接子控件,间接子控件


嫡子控件选择器


QDialog > QPushButton


选中所有Qdialog的直接孩子QPushButton

精细控制(子控件)

对于比较复杂的控件,往往由多个子控件构成,比如QComboBox则由文本框和下拉按钮构成,对于QT STYLE 允许我们分别对子控件进行样式设定,这就大大增强了样式的灵活性

举例:QComboBox的下拉点击按钮设置背景图片:

QComboBox::drop-down { image:url(dropdown.png) }

关于子控件更多信息与使用方法可以访问

http://qt-project.org/doc/qt-5/stylesheet-examples.html#customizing-qcombobox

伪状态控制

根据具体控件的状态不同,选择器也可以有不同的状态,依次对应控件在不同状态的现实效果

基本写法:

1.      伪状态和选择器类名之间,用一个冒号分隔。

QPushButton:hover { color: white }

2.      伪状态也可以反向选择。

例如:当我们要设置除了鼠标悬停状态外其他所有状态的字体颜色,则可以像下面这样设置:QRadioButton:!hover { color: red }

3.      伪状态也可以并列,之间用冒号连接,表示伪状态之间用AND计算:

QCheckBox:hover:checked { color: white }

QPushButton:hover:!pressed { color: blue; }

4.      伪状态之间可以用OR计算:

QCheckBox:hover, QCheckBox:checked { color:white }

5.      伪状态可以和子控件合起来使用:

QComboBox::drop-down:hover { image:url(dropdown_bright.png) }

STYLE基础知识的说明

我们控制STYLE主要是将STYLE添加到控件上,通过控制控件不同状态的STYLE以达到整体的显示效果

那对于控件,我将其分解为以下几部分来理解

从层次上来说:

控件可分为前景与背景

前景:多包含文件,图片等内容

背景:多包含图片,图形等内容

从结构上来说:

由于QT style是模拟CSS的布局结构,因此其满足CSS的盒子模型

从里到外的4个区域分别是:

1: content

2:  padding

3:  border

4:  margin

通过控制一个控件的前景,背景内容已经结构上的4个区域,我们就可以达到对一个控件为所欲为的控制

QT如何下使用QSS

1.       定义样式文件

2.       将样式文件添加到资源中

3.       代码端加载样式文件

CSS基本功能

CSS的强大在于组合功能的强大,这里只是简单介绍基本功能,将简单功能组合起来才能实现好看的效果。

CSS 背景属性(Background)


属性


描述


CSS


background


在一个声明中设置所有的背景属性。


1


background-attachment


设置背景图像是否固定或者随着页面的其余部分滚动。


1


background-color


设置元素的背景颜色。


1


background-image


设置元素的背景图像。


1


background-position


设置背景图像的开始位置。


1


background-repeat


设置是否及如何重复背景图像。


1


background-clip


规定背景的绘制区域。


3


background-origin


规定背景图片的定位区域。


3


background-size


规定背景图片的尺寸。


3

CSS 边框属性(Border 和 Outline)


属性


描述


CSS


border


在一个声明中设置所有的边框属性。


1


border-bottom


在一个声明中设置所有的下边框属性。


1


border-bottom-color


设置下边框的颜色。


2


border-bottom-style


设置下边框的样式。


2


border-bottom-width


设置下边框的宽度。


1


border-color


设置四条边框的颜色。


1


border-left


在一个声明中设置所有的左边框属性。


1


border-left-color


设置左边框的颜色。


2


border-left-style


设置左边框的样式。


2


border-left-width


设置左边框的宽度。


1


border-right


在一个声明中设置所有的右边框属性。


1


border-right-color


设置右边框的颜色。


2


border-right-style


设置右边框的样式。


2


border-right-width


设置右边框的宽度。


1


border-style


设置四条边框的样式。


1


border-top


在一个声明中设置所有的上边框属性。


1


border-top-color


设置上边框的颜色。


2


border-top-style


设置上边框的样式。


2


border-top-width


设置上边框的宽度。


1


border-width


设置四条边框的宽度。


1


outline


在一个声明中设置所有的轮廓属性。


2


outline-color


设置轮廓的颜色。


2


outline-style


设置轮廓的样式。


2


outline-width


设置轮廓的宽度。


2


border-bottom-left-radius


定义边框左下角的形状。


3


border-bottom-right-radius


定义边框右下角的形状。


3


border-image


简写属性,设置所有 border-image-* 属性。


3


border-image-outset


规定边框图像区域超出边框的量。


3


border-image-repeat


图像边框是否应平铺(repeated)、铺满(rounded)或拉伸(stretched)。


3


border-image-slice


规定图像边框的向内偏移。


3


border-image-source


规定用作边框的图片。


3


border-image-width


规定图片边框的宽度。


3


border-radius


简写属性,设置所有四个 border-*-radius 属性。


3


border-top-left-radius


定义边框左上角的形状。


3


border-top-right-radius


定义边框右下角的形状。


3


box-decoration-break

 
3


box-shadow


向方框添加一个或多个阴影。


3

Box 属性


属性


描述


CSS


overflow-x


如果内容溢出了元素内容区域,是否对内容的左/右边缘进行裁剪。


3


overflow-y


如果内容溢出了元素内容区域,是否对内容的上/下边缘进行裁剪。


3


overflow-style


规定溢出元素的首选滚动方法。


3


rotation


围绕由 rotation-point 属性定义的点对元素进行旋转。


3


rotation-point


定义距离上左边框边缘的偏移点。


3

CSS 字体属性(Font)


属性


描述


CSS


font


在一个声明中设置所有字体属性。


1


font-family


规定文本的字体系列。


1


font-size


规定文本的字体尺寸。


1


font-size-adjust


为元素规定 aspect 值。


2


font-stretch


收缩或拉伸当前的字体系列。


2


font-style


规定文本的字体样式。


1


font-variant


规定是否以小型大写字母的字体显示文本。


1


font-weight


规定字体的粗细。


1

CSS 外边距属性(Margin)


属性


描述


CSS


margin


在一个声明中设置所有外边距属性。


1


margin-bottom


设置元素的下外边距。


1


margin-left


设置元素的左外边距。


1


margin-right


设置元素的右外边距。


1


margin-top


设置元素的上外边距。


1

CSS 内边距属性(Padding)


属性


描述


CSS


padding


在一个声明中设置所有内边距属性。


1


padding-bottom


设置元素的下内边距。


1


padding-left


设置元素的左内边距。


1


padding-right


设置元素的右内边距。


1


padding-top


设置元素的上内边距。


1

CSS 定位属性(Positioning)


属性


描述


CSS


bottom


设置定位元素下外边距边界与其包含块下边界之间的偏移。


2


clear


规定元素的哪一侧不允许其他浮动元素。


1


clip


剪裁绝对定位元素。


2


cursor


规定要显示的光标的类型(形状)。


2


display


规定元素应该生成的框的类型。


1


float


规定框是否应该浮动。


1


left


设置定位元素左外边距边界与其包含块左边界之间的偏移。


2


overflow


规定当内容溢出元素框时发生的事情。


2


position


规定元素的定位类型。


2


right


设置定位元素右外边距边界与其包含块右边界之间的偏移。


2


top


设置定位元素的上外边距边界与其包含块上边界之间的偏移。


2


vertical-align


设置元素的垂直对齐方式。


1


visibility


规定元素是否可见。


2


z-index


设置元素的堆叠顺序。

 
         

CSS 文本属性(Text)


属性


描述


CSS


color


设置文本的颜色。


1


direction


规定文本的方向 / 书写方向。


2


letter-spacing


设置字符间距。


1


line-height


设置行高。


1


text-align


规定文本的水平对齐方式。


1


text-decoration


规定添加到文本的装饰效果。


1


text-indent


规定文本块首行的缩进。


1


text-shadow


规定添加到文本的阴影效果。


2


text-transform


控制文本的大小写。


1


unicode-bidi


设置文本方向。


2


white-space


规定如何处理元素中的空白。


1


word-spacing


设置单词间距。


1


hanging-punctuation


规定标点字符是否位于线框之外。


3


punctuation-trim


规定是否对标点字符进行修剪。


3


text-align-last


设置如何对齐最后一行或紧挨着强制换行符之前的行。


3


text-emphasis


向元素的文本应用重点标记以及重点标记的前景色。


3


text-justify


规定当 text-align 设置为 "justify" 时所使用的对齐方法。


3


text-outline


规定文本的轮廓。


3


text-overflow


规定当文本溢出包含元素时发生的事情。


3


text-shadow


向文本添加阴影。


3


text-wrap


规定文本的换行规则。


3


word-break


规定非中日韩文本的换行规则。


3


word-wrap


允许对长的不可分割的单词进行分割并换行到下一行。


3

QSS知识总结

时间: 2024-10-04 02:43:45

QSS知识总结的相关文章

qt之窗口换肤(一个qss的坑:当类属性发现变化时需要重置qss)

1.相关文章 Qt 资源系统qt的moc,uic,rcc命令的使用 2.概要    毕业两年了,一直使用的是qt界面库来开发程序,使用过vs08.10.13等开发工具,并安装了qt的插件,最近在做客户端换肤功能,所以就对qt的qrc做了点儿研究,我是一个实干派(可能有点儿虚),相对于看文档来说.本文开头我就给出了两篇博客,这两篇博客对我理解qrc这个东西有很大的帮助,接下来我就简单分析下我的理解. 首先说明下qrc是qt的东西,而不属于vs,这也很容易证明,那就是vs的工程师不识别qrc文件的,

Qt控件样式之QSS

QSS常用于Qt的控件样式美化,合理地使用Qss可以完成在不改动代码的情况下改变Qt界面的样式. 官方提供的例子: http://qt-project.org/doc/qt-4.8/stylesheet-examples.html 这个是官方提供的例子,只有qt-4.8的,目前Qt最新版本是Qt5.4,但似乎在qss这块没有较大的更新,同时有关帮助手册可以在Qt Assistant中寻找. 在这个Qt Style Sheets Reference中有QSS所支持的所有属性.状态,QSS是参照CS

MySQL数据库基础知识

day02 MySQL数据库基础知识 一.基础知识概述: 基础决定你这门课程的学习成败!只有学习好这些基础知识以后,你才能真正的运用自如.才能够对数据库有更深入的了解,道路才会越走越远. 二.基础知识: 1.数据库(database):数据库就好比是一个物理的文档柜,一个容器,把我们整理好的数据表等等归纳起来. 创建数据库命令:        create database 数据库名; 2.查看数据库         show databases; 3.打开指定的数据库         use 

前端里移动端到底比pc端多哪些知识?

前端里移动端到底比pc端多哪些知识,为啥面试时好多公司都问h5水平如何? 我做过几年的web前端开发,就简单谈谈自己的感受吧. 首先来看看PC端和移动端在前端开发上的一些区别: (1)PC考虑的是浏览器兼容性,移动端开发考虑的更多的是手机兼容性,因为目前不管是android手机还是ios手机,一般浏览器用的都是webkit内核,所以做移动端开发,更多考虑的应该是手机分辨率的适配,和不同操作系统的略微差异化: (2)在部分事件的处理上,移动端自然是偏向于触屏的,所以触屏事件的一些规律要多摸索一下,

linux入门基础知识及简单命令介绍

linux入门基础知识介绍 1.计算机硬件组成介绍 计算机主要由cpu(运算器.控制器),内存,I/O,外部存储等构成. cpu主要是用来对二进制数据进行运算操作,它从内存中取出数据,然后进行相应的运算操作.不能从硬盘中直接取数据. 内存从外部存储中取出数据供cpu运存.内存的最小单位是字节(byte) 备注:由于32的cpu逻辑寻址能力最大为32内存单元.因此32位cpu可以访问的最大内存空间为:4GB,算法如下: 2^32=2^10*2^10*2^10*2^2 =1024*1024*1024

认知,构建个人的知识体系(上)

1.前言 本文将聊聊我对构建个人知识体系的一些想法,主要是为了提升自我认知.从个人经历开始,谈谈对知识的划分,也就是一个是什么,为什么的过程. 2.缘起 把时间回到一年前,那时候我工作快一年了,得益于前面的一些努力,工作比较顺利.特别是技术上,没有遇到太多过无法解决的问题.同时也开始迷茫,工作难道就是这个轻松的样子?三五年之后那不是很无趣,该怎么办? 想找到这个问题的答案,而最好的方式莫过于,亲自去了解那些三五年工作经验的人是怎么的样子. 因此从那时候起,关注了不少来公司面试的人的简历,也有过几

知识汇总都在这里了,赶紧点开看看吧!

微信公众号:Web前端精髓 Web前端技术由html.css和JavaScript三大部分构成,是一个庞大而复杂的技术体系,其复杂程度不低于任何一门后端语言.而我们在学习它的时候往往是先从某一个点切入,然后不断地接触和学习新的知识点,因此对于初学者很难理清楚整个体系的脉络结构. Web前端精髓是一个分享前端知识的平台,内容包括HTML.CSS.javascript 等和前端技术相关的一切,如果您想对前端有更多的了解,那就持续关注我们,目的是帮助大家审查自己的知识结构是否完善,希望我的文章对你们有

学习虚拟化技术需要掌握的知识与能力(未完成版)

我从1993年学习计算机,有过短期的C语言开发经历,现在主要从事网络与系统集成的工作.我可以算是学习计算机比较"早"的一批人了. 1993年的时候,我是从MS-DOS 3.30开始,直到最后的MS-DOS 6.22.Windows系统是从Windows 3.1(中文版)开始,再到Windows 3.11.Windows 95.98一直到现在的Windows 10. 组建Windows网络是在1996年河北省国税局全省联网,是从Windows NT 3.51开始,到后来的Windows

CentOS下的路由知识及配置路由

博文目录 简介 上一篇博文已经讲解了IP地址的配置,那么有IP,就准备开始进行通信吧,网络之间的通信主要是依靠路由器,当然生成环境中是拥有路由器的,但是系统中的路由配置也是需要了解一下地,今天讲解一下软路由的显现,与一个路由的小实验 linux下需要启用ip_forword 启用路由功能 echo 1 > /proc/sys/net/ipv4/ip_forword 一.路由表中的接口 到达目标网段从本路由器的那个接口能到达,这个借口就本路由的记录接口 1.如果目标网络和路由器直接相连,网关即是路