zoukankan      html  css  js  c++  java
  • Qt样式表的使用

      Qt中可以灵活的使用层叠样式表(CSS),其语法和CSS很相似。因为HTML CSS的灵活性,所以可以很方便的为QT界面设计自己需要的外观。除了子类化Style类,使用QT样式表(QStyleSheet)是另一种快速改变QT程序UI风格的方法,它很大程度上借鉴和参考了 HTML层叠样式表的语法和思想。

      StyleSheet文件的默认后缀名为qss,可通过命令行参数 -stylesheet filename.qss 来设置样式表,也可通过QApplication::setStyleSheetQWidget::setStyleSheet来设置应用程序或特定控件要使用的样式表。::setStyleSheet函数的参数是字符串(不是qss文件的名字,而是样式表的内容),所以直接使用的话,不方便一次设置大量的规则,但可使用资源文件将qss样式表嵌入到程序中,然后通过QApplication::setStyleSheet来使用。

      下面简单介绍Qt样式表(QSS)的使用。

    1、在当前工程目录下建立.qss格式的文件,如:css.qss,在其中编写Qt支持的CSS代码,如下所示:

    QPushButton:hover
    {
        color:yellow;
        background-color:green;
    }
    
    QPushButton[text="Cancel"]
    {
        color:red;
    }
    
    QTableView::item:hover,QLineEdit:hover,QComboBox:hover,QTextEdit:hover
    {
        background-color:rgb(127,255,212);
    }
    
    QMenuBar,QStatusBar
    {
        background-color:rgb(100,149,237);
    }

    2、在Qt程序中设置该样式表

      在Qt程序的合适位置添加如下代码:

    //读取样式表
    QFile qssFile("css.qss");//资源文件":/css.qss"
    qssFile.open(QFile::ReadOnly);
    if(qssFile.isOpen())
    {
        QString qss = QLatin1String(qssFile.readAll());
        qApp->setStyleSheet(qss);
        qssFile.close();
    }

      在程序中可通过qApp设置样式表,也可通过控件对象设置样式表。

    3、QSS语法

      同CSS一样,它也由Selector和Declaration组成,如:

    QPushButton 
    { 
        color: red;
    }

      若有几个Selector指定了相同的Declaration,可使用逗号将Selector选择器分开,如:

    QPushButton, QLineEdit, QComboBox
    { 
        color: red; 
    }

    注:

      CSS的语法请参见:http://www.w3school.com.cn/css/css_syntax.asp

      Qt Style Sheets的详细介绍请参见官网:http://doc.qt.io/qt-4.8/stylesheet.html

  • 相关阅读:
    Java基础-集合框架的学习大纲
    Java多线程并发学习-进阶大纲
    Spring学习大纲
    Netty学习大纲
    分布式学习大纲
    数据库学习大纲
    缓存学习大纲
    JVM-jvm学习大纲(0)
    多线程学习-基础(十三)(学习参考·网摘) ArrayBlockingQueue源代碼解析(base jdk 1.8)
    C#数字图像处理算法学习笔记(一)--C#图像处理的3中方法
  • 原文地址:https://www.cnblogs.com/gaohongchen01/p/4534194.html
Copyright © 2011-2022 走看看