Qt实战案例(13)(序)——以QToolButton为例介绍Qt界面外观设计

一、项目介绍

以QToolButton为例,详解Qt界面外观(QSS)设计。

二、项目基本配置

新建一个Qt案例,项目名称为“Test”,基类选择“QWidget”,创建UI界面复选框的选中状态,完成项目创建。

三、UI界面设计

UI界面内放置一个ToolButton,如下:
在这里插入图片描述

四、主程序实现

4.1 widget.h头文件

声明按钮点击槽函数:

private slots:
    void on_toolButton_clicked();

4.2 widget.cpp源文件

核心代码如下:

    ui->toolButton->setToolButtonStyle(Qt::ToolButtonTextBesideIcon);
    ui->toolButton->setText("更新设置");
    ui->toolButton->setIcon( QIcon(":/img/right.png"));
    ui->toolButton->setProperty("START","Up");            //设置为未按下状态

定义按钮点击槽函数:

void Widget::on_toolButton_clicked()
{
    if(ui->toolButton->property("START")=="Up")          //之前是未按下
    {
     ui->toolButton->setProperty("START","Down");     //设置为按下
     qDebug()<<ui->toolButton->property("START");

     ui->toolButton->setText("取消设置");
     ui->toolButton->setIcon( QIcon(":/img/wrong.png"));
     //......
    }
    else
    {
       ui->toolButton->setProperty("START","Up");    //设置为未按下状态

       ui->toolButton->setText("更新设置");
       ui->toolButton->setIcon( QIcon(":/img/right.png"));
    //......
    }
}

然后定义QSS文件:

    //应用样式 apply the qss style
        QFile file(":/qss/main.qss");
        file.open(QFile::ReadOnly);
        QTextStream filetext(&file);
        QString stylesheet = filetext.readAll();
        this->setStyleSheet(stylesheet);
     file.close();

4.3 main.qss

在文件中添加一个资源文件,命名为main.qss,内容如下:

/*正常状态下*/
QToolButton[START="Up"] {                                                         
        border-radius: 20px;
        border: none;
        padding-left :30px;
        color: rgb(255,255,255);
        background: rgb(56,167,222); 
}


QToolButton[START="Up"]:hover {                                                              

        padding-bottom: 2px;
        background: rgb(0,205,252); 
}

QToolButton[START="Up"]:checked,QToolButton[START="Up"]:pressed {      
        background: rgb(6,144,175); 
}


/*取消状态下*/
QToolButton[START="Down"] {                                                            
        border-radius: 20px;
        border: none;
     padding-left :30px;
     color: rgb(255,255,255);
     background: qlineargradient(spread:pad,                   
                  x1:0, y1:0, x2:0, y2:1,
              stop:0 rgba(255,176,30, 255), 
              stop:0.6 rgba(254,139,91, 255),
              stop:1.0 rgba(254,176,143, 255));
}

QToolButton[START="Down"]:hover {        
        padding-bottom: 2px;
        background: qlineargradient(spread:pad,               
                 x1:0, y1:0, x2:0, y2:1,
              stop:0 rgba(255,176,30, 255), 
              stop:0.6 rgba(255,74,0, 255),
              stop:1.0 rgba(255,183,153, 255)); 
}

五、效果演示

效果如下:
在这里插入图片描述

如果没有看懂的话,完整代码可以参考:
https://download.csdn.net/download/didi_ya/75661766


ok,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~

  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

wendy_ya

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

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

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

打赏作者

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

抵扣说明:

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

余额充值