【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;"
    "}"
     );

}

效果展示

在这里插入图片描述

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

如何将按钮按下后保持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);
}

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

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

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

button->setCheckable(true);
button->setChecked(true);//只能设置一个,设置哪个默认显示哪个
button->setAutoExclusive(true);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cappuccino-jay

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值