【Qt 学习笔记】QWidget的styleSheet属性 | RGB | 在线调色板


  • 博客主页:Duck Bro 博客主页
  • 系列专栏:Qt 专栏
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍

QWidget的styleSheet属性

文章编号:Qt 学习笔记 / 20


一、styleSheet属性

1. 简介

Qt中的styleSheet属性用于设置界面的样式。它是一个QString类型的属性,可以接受一系列的CSS样式规则。

使用styleSheet属性可以实现界面的美化和个性化定制。可以在styleSheet中使用普通的CSS语法和属性,也可以使用QT提供的特殊属性。更详细的用法可以查阅QT的官方文档。

CSS是什么?查看文章:【HTML/CSS】入门导学篇

以下是一些常见的使用方法和示例:

  1. 设置背景颜色:
widget->setStyleSheet("background-color: yellow;");
  1. 设置字体样式:
widget->setStyleSheet("font-family: Arial; font-size: 12px;");
  1. 设置边框样式:
widget->setStyleSheet("border: 1px solid black;");
  1. 设置按钮样式:
button->setStyleSheet("QPushButton { background-color: blue; color: white; } QPushButton:hover { background-color: red; }");
  1. 设置文本框样式:
lineEdit->setStyleSheet("QLineEdit { background-color: gray; color: white; } QLineEdit:focus { background-color: blue; }");

2. API

API说明
QString styleSheet() const获取控件的样式表。
void setStyleSheet(const QString &styleSheet)设置控件的样式表。

3. 代码示例

示例1:样式表设置文本样式
  1. 在界⾯上创建 label
    在这里插入图片描述

  2. 打开样式表
    在这里插入图片描述

  3. 编辑右侧的 styleSheet 属性, 设置样式
    在这里插入图片描述
    注意:此处的语法格式同 CSS, 使⽤键值对的⽅式设置样式. 其中键和值之间使⽤ : 分割. 键值对之间使⽤; 分割

  4. 也可以使用软件自带的方式添加字体和添加颜色
    在这里插入图片描述

  5. 运行程序,查看文本效果
    在这里插入图片描述

示例2:代码实现切换夜间模式
  1. 在界⾯上创建⼀个多⾏输⼊框 (Text Edit) 和两个按钮(PushButton)
    在这里插入图片描述
  2. 编写widget.cpp
    在这里插入图片描述
  3. 运行程序,查看效果
  • 浅色模式
    在这里插入图片描述
  • 深色模式
    在这里插入图片描述

文件代码:

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();



private slots:
    void on_pushButton_light_clicked();

    void on_pushButton_dark_clicked();

private:
    Ui::Widget *ui;
};
#endif // WIDGET_H
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
}

Widget::~Widget()
{
    delete ui;
}



void Widget::on_pushButton_light_clicked()
{
    this->setStyleSheet("background-color: #f3f3f3");
    ui->textEdit->setStyleSheet("background-color: #fff; color: #000;");
    ui->pushButton_light->setStyleSheet("color: #000");
    ui->pushButton_dark->setStyleSheet("color: #000");
}

void Widget::on_pushButton_dark_clicked()
{
    this->setStyleSheet("background-color: #333");
    ui->textEdit->setStyleSheet("background-color: #333; color: #fff;");
    ui->pushButton_light->setStyleSheet("color: #fff");
    ui->pushButton_dark->setStyleSheet("color: #fff");
}


二、在线调色板

1. 介绍

在线调色板是一种用于选择和调整颜色的软件或工具。它可以帮助用户找到特定颜色的代码或值,并提供调整颜色的功能,例如改变亮度、饱和度、对比度等。在线调色板通常可以以网页形式呈现,用户可以通过拖动滑块或输入数值来调整颜色。
在这里插入图片描述

2. 在线网页链接

点击蓝色文字跳转 在线调色板链接https://www.sojson.com/web/online.html


三、计算机的颜色表示(RGB)

1. 什么是RGB

RGB是英文Red(红)、Green(绿)、Blue(蓝)的首字母缩写,是一种常用于计算机图形学和电视显示的颜色模型。在RGB模型中,所有的颜色都是通过红、绿、蓝三种基本颜色的不同强度和组合来表示的。通过调整这三种基本颜色的强度,可以创建出各种不同的颜色。在计算机系统中,每个颜色通道的取值范围是0~255,其中0代表最小强度,255代表最大强度。通过将这三种颜色的强度组合起来,可以创建出超过1600万种不同的颜色。

2. 红绿蓝的参数设置

混合三种不同颜⾊的数值⽐例, 就能搭配出千千万万的颜⾊出来

  • rgb(255, 0, 0) 或者 #FF0000 或者 #F00 表⽰纯红⾊.
    在这里插入图片描述

  • rgb(0, 255, 0) 或者 #00FF00 或者 #0F0 表⽰纯绿⾊.
    在这里插入图片描述

  • rgb(0, 0, 255) 或者 #0000FF 或者 #00F 表⽰纯蓝⾊.
    在这里插入图片描述

  • rgb(255, 255, 255) 或者 #FFFFFF 或者 #FFF 表⽰纯⽩⾊.
    在这里插入图片描述

  • rgb(0, 0, 0) 或者 #000000 或者 #000 表⽰纯⿊⾊.
    在这里插入图片描述


在这里插入图片描述

  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Qt StyleSheet是一种用于自定义Qt应用程序用户界面的技术,可以通过对QSS文件进行定义来设置控件的外观和样式。使用Qt StyleSheet开发者可以实现自定义按钮、标签、进度条、滑块等控件的样式效果,使应用程序的外观更加美观和个性化。 在线使用Qt StyleSheet十分方便。首先,我们需要创建一个QSS文件,可以使用文本编辑器编写QSS的样式规则,定义不同控件的外观效果。然后,将QSS文件加载到Qt应用程序中,可以通过调用QWidget的setStyleSheet()函数将QSS应用到单个控件,或者使用QApplication的setStyleSheet()函数将QSS应用到整个应用程序。 在线使用Qt StyleSheet意味着我们可以实时修改QSS样式,当样式文件发生变化时,应用程序会自动刷新并应用新的样式,无需重新启动应用程序。这样,我们就可以实时调整控件的大小、颜色、字体、边框等属性,达到我们想要的效果。 Qt StyleSheet提供了丰富的样式选择器和样式属性开发者可以根据自己的需要定义不同控件的不同状态下的样式效果。此外,Qt还提供了一些预定义的样式类和样式属性,可以直接使用或者基于其进行修改。开发者还可以通过样式继承来减少代码量,将一些共同的样式属性定义在父类样式中,子类的样式只需要定义特定的样式属性即可。 总之,Qt StyleSheet是一种非常灵活和强大的样式定义方法,可以帮助我们轻松定制和美化Qt应用程序的用户界面。在线使用Qt StyleSheet让我们能够实时调整样式效果,提高开发效率,使应用程序更加吸引人。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Duck Bro

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

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

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

打赏作者

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

抵扣说明:

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

余额充值