QT c++ 样式 设置 按钮(QPushButton)的渐变色美化

上一篇文章中描述了标签的渐变色美化, 本文描述按钮的渐变色美化

1.头文件

#ifndef WIDGET_H

#define WIDGET_H

#include <QWidget>

//#include "CustomButton.h"
#include <QVBoxLayout>
#include <QLinearGradient>
#include <QPushButton>

//#include <QLabel>

//#include <QTimer>

QT_BEGIN_NAMESPACE

namespace Ui {

class Widget;

}

QT_END_NAMESPACE

class Widget : public QWidget

{

Q_OBJECT

public:

Widget(QWidget *parent = nullptr);

~Widget();

void initUI() ;

//void setButton(QPushButton * button,int color,int width,int height);

private:

Ui::Widget *ui;

//CustomButton *button;

QPushButton *button2;

// QLabel *label;

// QTimer *timer;

//int counter=0;

bool flag_on=false;//on/off标志

};

#endif // WIDGET_H

2.cpp文件

#include "widget.h"

#include "ui_widget.h"

Widget::Widget(QWidget *parent)

: QWidget(parent)

, ui(new Ui::Widget)

{

ui->setupUi(this);

initUI();

}

Widget::~Widget()

{

delete ui;

}

void Widget::initUI ()

{

QVBoxLayout * mainlayout = new QVBoxLayout(this);//指定布局属于啥组件

setStyleSheet("background-color:rgb(160,203,254);");

QPushButton *button2=new QPushButton(this) ;

button2->setFixedWidth (65);

button2->setFixedHeight (33);

//button2->setStyleSheet("background-color:#dddddd");//初始背景颜色

//setButton(button2,4,65,33);

QObject::connect(button2, &QPushButton::pressed,

[button2,this]()//lambda函数

{

flag_on=!flag_on ;//状态取反

//qDebug("pressed!");

if(flag_on)

{

QString color_on=

"border:1px solid gray;"

"background-color: qlineargradient(x1: 0, y1: 0, x2: 0, y2: 1, "

"stop: 0 #669066,"

"stop: 0.5 #43ff43,"

"stop: 1 #669066);";

//"background-color:#00ff73;";//上面几行是线性过渡色

button2->setStyleSheet(color_on);

//qDebug("On!");

}

else

{

QString color_off=

"border:1px solid gray;"

"background-color: qlineargradient(x1: 0, y1: 0, x2:0, y2: 1, "

"stop: 0.1 #aaaaaa,"

"stop: 0.5 #ffffff,"

"stop: 1 #cccccc);";

// "background-color:#f6f6f6;";//上面几行是线性过渡色

button2->setStyleSheet(color_off) ;

//qDebug("Off!");

}

});

mainlayout->addWidget(button2);//指定布局包含啥组件

this->setLayout(mainlayout);

}

//效果,两种状态的渐变色效果如下

off on

相关推荐
道不尽世间的沧桑12 分钟前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
久绊A20 分钟前
Python 基本语法的详细解释
开发语言·windows·python
软件黑马王子4 小时前
C#初级教程(4)——流程控制:从基础到实践
开发语言·c#
cpp_learners4 小时前
QT 引入Quazip和Zlib源码工程到项目中,无需编译成库,跨平台,压缩进度
qt·zlib·加密压缩·quazip
闲猫4 小时前
go orm GORM
开发语言·后端·golang
黑不溜秋的5 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
李白同学5 小时前
【C语言】结构体内存对齐问题
c语言·开发语言
黑子哥呢?7 小时前
安装Bash completion解决tab不能补全问题
开发语言·bash
青龙小码农7 小时前
yum报错:bash: /usr/bin/yum: /usr/bin/python: 坏的解释器:没有那个文件或目录
开发语言·python·bash·liunx
大数据追光猿7 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法