• 【QT】QT 按钮保持按下时的样式


    按钮设计样式

    MainWidget::MainWidget(QWidget *parent) :
        QWidget(parent),
        ui(new Ui::MainWidget)
    {
        ui->setupUi(this);
        _setupUi();
        
        setStyleSheet(
        /**正常情况下样式**/
        "QPushButton{"
            "font: 24pt '微软雅黑';"
            "color: #2f3640;"
            "background-color: #f5f6fa;"
            "border-color: #2f3640;"
            "border-radius: 15px;"
            "border-style: solid;"
            "border-width: 2px;"
            "padding: 5px;"
        "}"
        
        /**鼠标停留在按钮上的样式**/
        "QPushButton::hover{"
            "color: #FFFFFF;"
            "background-color: #718093;"
            "border-color: #2f3640;"
        "}"
    
        /**鼠标按压下去的样式**/
        "QPushButton::pressed,QPushButton::checked{"
            "color: #FFFFFF;"
            "background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:0, y2:1, stop:0 #273c75, stop:1 #487eb0);"
        "}"
    
        /**按钮失能情况下样式**/
        "QPushButton::disabled{"
            "color: #FFFFFF;"
            "background-color: #dcdde1;"
            "border-color: #dcdde1;"
        "}"
         );
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42

    效果展示

    在这里插入图片描述

    但是这样设置按钮的样式只是在鼠标操作下会显示,当鼠标移出后,样式就消失了,这样这几个按钮又都回到白色情况下,无法让用户知道刚刚点击的是显示哪个窗口。

    如何将按钮按下后保持press样式下的样式

    1、将所有按钮的如下的两个状态均选中

    在这里插入图片描述

    2、在每个按钮的槽函数后面加上setDown()函数
    void MainWidget::on_RealDataBtn_clicked()
    {
        ui->RealDataBtn->setDown(true);
        ui->HistDataBtn->setDown(false);
        ui->DataStatisticBtn->setDown(false);
        ui->StatusMonitorBtn->setDown(false);
        ui->FaultQueryBtn->setDown(false);
        ui->OnLineHelpBtn->setDown(false);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    将对应的button后面setDown设置为true,其余按钮的槽函数后依次操作。

    3、另外还可以通过添加代码的形式添加

    在这里插入图片描述
    对于 checked 属性,想要设置哪个按钮默认按下,就在其后勾选上,不选的话默认选择第一个。

    button->setCheckable(true);
    button->setChecked(true);//只能设置一个,设置哪个默认显示哪个
    button->setAutoExclusive(true);
    
    • 1
    • 2
    • 3
  • 相关阅读:
    MySQL索引、事务、存储引擎
    xargs 命令详解
    一种用于环境声源的被动到达角(AoA)提取算法(Matlab代码实现)
    自动驾驶寻找「商业闭环」
    jenkins部署springboot项目、制作Dockerfile启动在docker容器中
    java毕业设计爱宠医院管理系统mybatis+源码+调试部署+系统+数据库+lw
    Vue中自定义事件
    Kubernetes: kube-controller-manager 源码分析
    ANSVC无功补偿装置助力江苏某环保能源项目
    @Elasticsearch之深度应用及原理剖析--文档搜索机制剖析
  • 原文地址:https://blog.csdn.net/Cappuccino_jay/article/details/126776937