一键换肤的Qt-Advanced-Stylesheets

news2025/3/12 18:16:38

项目简介

能在软件运行时对 CSS 样式表主题(包括 SVG 资源和 SVG 图标)进行实时颜色切换的Qt项目。

项目预览:
1
2

项目地址

地址:Qt-Advanced-Stylesheets

本地编译环境

Win11 家庭中文版

Qt5.15.2 (MSVC2019)

Qt Creator15.0.1

本地编译

克隆到本地后,直接使用Qt Creator打开.pro,选择full_features项目编译运行即可。
3
4
5

一键换肤功能解析

一键换主题皮肤如何实现?

首先通过.ui文件可以看到,使用的都是Qt提供的标准控件,无其他自定义控件:

6

风格主配置文件:./styles/qt_material/material.json

主要定义程序图标、完整CSS文件、主题、图标颜色以及调色版palette相关配置。
7

主题配置文件:./styles/qt_material/themes/*.xml

配置dark、light主题及其下各级标题的颜色。
8

完整CSS文件:./styles/qt_material/material.css.template

就是配置界面中控件样式,不过颜色确实根据不同主题配置文件中定义的颜色变量。
9

至此可以确认一键换肤的大致实现框架:风格 -> 主题 -> CSS样式

①读取风格主配置文件 (./styles/qt_material/material.json),加载对应的程序图标、CSS样式、默认主题以及调色板相关配置。

②读取默认主题配置文件 (./styles/qt_material/themes/dark_teal.xml),获取各级主题对应色值配置。

③读取CSS文件,应用②中读取色值并实际应用控件样式。

④对于当前风格(即./styles/qt_material),切换不同主题则加载对应主题配置文件(./styles/qt_material/themes/*.xml),再刷新CSS样式,即用户每次手动切换主题,重复②、③步骤。

⑤**按现有框架设计,还可扩展实现风格(style)切换功能。**目前只有一种(即./styles/qt_material),后可扩展实现切换风格(style)功能,每次切换style,则重新加载风格主配置文件、读取该风格默认主题配置文件、再应用CSS样式。即用户每次手动切换风格,重复①、②、③步骤。

接着通过代码验证下上述逻辑:

可直接在主窗口构造函数中看到上述逻辑的接口调用:

CMainWindow::CMainWindow(QWidget *parent)
    : QMainWindow(parent),
      d(new MainWindowPrivate(this))
{
    d->ui.setupUi(this);

    QString AppDir = qApp->applicationDirPath();    //获取程序运行目录
    QString StylesDir = STRINGIFY(STYLES_DIR);      //获取风格目录,STYLES_DIR在full_feature.pro中定义:DEFINES += "STYLES_DIR=$$PWD/../../styles"
    d->AdvancedStyleSheet = new acss::QtAdvancedStylesheet(this);      //封装的风格主题样式类
    d->AdvancedStyleSheet->setStylesDirPath(StylesDir);                //设置风格目录
    d->AdvancedStyleSheet->setOutputDirPath(AppDir + "/output");        //设置程序风格主题样式类资源的输出目录
    d->AdvancedStyleSheet->setCurrentStyle("qt_material");              //设置当前风格
    d->AdvancedStyleSheet->setDefaultTheme();                           //设置当前风格的默认主题
    d->AdvancedStyleSheet->updateStylesheet();                          //确定风格主题后更新整体样式
    setWindowIcon(d->AdvancedStyleSheet->styleIcon());                  //设置风格配置中的默认程序图标
    qApp->setStyleSheet(d->AdvancedStyleSheet->styleSheet());           //应用CSS
    connect(d->AdvancedStyleSheet, SIGNAL(stylesheetChanged()), this,   //切换风格信号和槽连接
    	SLOT(onStyleManagerStylesheetChanged()));

    d->createThemeColorDockWidget();
    d->fillThemeMenu();
    d->setSomeIcons();
    d->setupQuickWidget();
    d->loadThemeAwareToolbarActionIcons();
}

10

这里还想再提一下的是,CSS中的勾选框、复选框之类的控件样式,有些是通过设置svg图标实现的,在切换主题是可以发现图标颜色也发生了变化:
11
切换后:
12

说明图标有发生变化,通过切换前后对比,可以发现确实图标确实有发生变化:
13

切换后:
14

代码中是通过封装的CSVGIconEngine(继承自QIconEngine)实现的:

// SVG颜色替换核心逻辑
void QtAdvancedStylesheet::replaceSvgColors(QByteArray& SvgContent, const tColorReplaceList& ColorReplaceList) {
    const auto& ReplaceList = ColorReplaceList.isEmpty() ? d->iconColorReplaceList() : ColorReplaceList;
    for (const auto& Replace : ReplaceList) {
        d->replaceColor(SvgContent, Replace.first, Replace.second); // 直接替换二进制数据
    }
}

// 动态更新所有图标颜色
void CSVGIconEngine::updateAllIcons() {
    for (auto Engine : *IconEngineInstances) {
        Engine->update(); // 重新调用replaceSvgColors
    }
}

通过自定义图标引擎(CSVGIconEngine)和颜色替换逻辑(replaceSvgColors),结合风格主配置文件(./styles/qt_material/material.json)中的"icon_colors"配置的颜色映射,实现了SVG图标的动态颜色切换。

当主题变化时,所有图标会自动更新,无需重新加载文件。

总结

通过对Qt-Advanced-Stylesheets源码阅读及本地调试,剖析了Qt-Advanced-Stylesheets项目一键动态切换主题功能的核心实现,即通过不同的 风格 -> 主题 -> 样式 配置架构管控软件整体风格样式。

需要注意的是控件相关样式设置需在CSS文件中配置,若在代码或ui文件中设置会无法动态切换,同时需要注意css文件中的颜色值需要通过颜色模板变量而不是具体数值设置。

而对于混框架(如Qt + MFC)大型项目的一键切换风格主题样式,能否借鉴该实现方式,有待商榷。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2313879.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

golang 静态库 Undefined symbol: __mingw_vfprintf

正常用golang编译一个静态库给 其他语言 调用,编译时报错 Error: Undefined symbol: __mingw_vfprintf 很是奇怪,之前用用golang写静态库成功过,编译也没问题,结果却是截然不同。 试了很多次,发现唯一的差别就是在 …

Linux 网络:skb 数据管理

文章目录 1. 前言2. skb 数据管理2.1 初始化2.2 数据的插入2.2.1 在头部插入数据2.2.2 在尾部插入数据 2.2 数据的移除 3. 小结 1. 前言 限于作者能力水平,本文可能存在谬误,因此而给读者带来的损失,作者不做任何承诺。 2. skb 数据管理 数…

wireguard搭配udp2raw部署内网

前言 上一篇写了使用 wireguard 可以非常轻松的进行组网部署,但是如果服务器厂商屏蔽了 udp 端口,那就没法了 针对 udp 被服务器厂商屏蔽的情况,需要使用一款 udp2raw 或 socat 类似的工具,来将 udp 打包成 tcp 进行通信 这里以…

Qwen/QwQ-32B 基础模型上构建agent实现ppt自动生成

关心Qwen/QwQ-32B 性能测试结果可以参考下 https://zhuanlan.zhihu.com/p/28600079208https://zhuanlan.zhihu.com/p/28600079208 官方宣传上是该模型性能比肩满血版 DeepSeek-R1(671B)! 我们实现一个 使用Qwen/QwQ-32B 自动生成 PowerPoi…

PostgreSQL17(最新版)安装部署

PostgreSQL 17已与2024年9月26日正式发布!!! 一、Postgres概述 官网地址:PostgreSQL: The world’s most advanced open source database Postgres作为最先进的开源数据库( the latest version of the world’s most…

【AI大模型智能应用】Deepseek生成测试用例

在软件开发过程中,测试用例的设计和编写是确保软件质量的关键。 然而,软件系统的复杂性不断增加,手动编写测试用例的工作量变得异常庞大,且容易出错。 DeepSeek基于人工智能和机器学习,它能够依据软件的需求和设计文…

【高级篇】大疆Pocket 3加ENC编码器实现无线RTMP转HDMI进导播台

【高级篇】大疆Pocket 3加ENC编码器实现无线RTMP转HDMI进导播台 文章目录 准备工作连接设备RTMP概念ENCSHV2推流地址设置大疆Pocket 3直播设置总结 老铁们好! 很久没写软文了,今天给大家带了一个干货,如上图,大疆Pocket 3加ENC编…

机器人交互系统 部署构建

环境要求 Ubuntu 20.04 或更高版本ROS Noetic 或兼容版本Python 3.8 安装步骤 1. 安装ROS环境(如未安装) sudo apt update sudo apt install ros-noetic-desktop-full source /opt/ros/noetic/setup.bash2. 创建工作空间并克隆代码 mkdir -p ~/code…

创建模式-工厂方法模式(Factory Method Pattern)

江城子乙卯正月二十日夜记梦 目的动机简单工厂示例代码 目的 定义一个创建对象的接口,该接口的子类具体负责创建具体的对象。工厂方法模式将对象的实例化延迟到子类。简单工厂是直接在创建方法中负责所有的产品的生成,造成该方法臃肿,并且当…

【eNSP实战】交换机配置端口隔离

交换机端口隔离可以实现在同一个VLAN内对端口进行逻辑隔离,端口隔离分为L2层隔离和L3层隔离,这里只进行L2层隔离演示。 拓扑图 路由器AR1配置GE 0/0/1配置IP,其余PC主机各自配置IP和网关。 现将PC1到PC4四个主机全部进行L2层隔离&#xff0c…

人脸识别之数据集中 PI20 和 CFMT 之间关联的模型预测贝叶斯(Python+论文代码实现)

代码文件(联系作者点击这里末尾) 代码文件描述如下: subjective_objective.ipynb和:这分别是实际的笔记本和 Web 浏览器友好的只读版本。此笔记本读取数据,执行一些预处理,并包含论文中使用的模型规范。它…

静态时序分析:无法满足的生成时钟(TIM-255警告、UITE-461或PTE-075错误)

相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html?spm1001.2014.3001.5482 在阅读本文前,强烈建议首先阅读介绍生成时钟的文章,尤其是其中关于时钟极性和反相的相关内容。 静态时序分析:SDC约束命令cr…

VSTO(C#)Excel开发2:Excel对象模型和基本操作

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 源码指引:github源…

途游游戏25届AI算法岗内推

熟悉常用的编程语言,如Python、R等,具有良好的编码和调试能力;对常用的机器学习算法和深度学习框架(如TensorFlow、PyTorch等)有深入理解,对大型语言模型有一定了解,具备模型部署和微调的实践经…

【数据分析大屏】基于Django+Vue汽车销售数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅

目录 一、项目背景 二、项目创新点 三、项目功能 四、开发技术介绍 五、项目功能展示 六、权威视频链接 一、项目背景 汽车行业数字化转型加速,销售数据多维分析需求激增。本项目针对传统报表系统交互性弱、实时性差等痛点,基于DjangoVue架构构建…

OpenCV应用:三种图像风格化案例

OpenCV 本身主要用于计算机视觉任务,例如图像处理、边缘检测、物体识别等,虽然它并不直接提供像 Photoshop 或其他艺术设计软件那样的 "风格化" 功能,但你可以通过一些图像处理技术在 OpenCV 中实现不同风格化效果。 1. 卡通化效果…

【Axure资料】110套优质可视化大屏模板+图表组件+科技感元件等

本作品集包含110套高保真可视化大屏模板,以及丰富的图表组件和科技感元件,旨在满足各行业对数据可视化展示的需求。所有模板和组件均基于Axure RP 9软件设计,确保高质量的交互体验和视觉效果。 作品类型:Axure原型模板 兼容版本&…

VanillaVueSvelteReactSolidAngularPreact前端框架/库的简要介绍及其优势

VanillaVueSvelteReactSolidAngularPreact前端框架/库的简要介绍及其优势。以下是这些前端框架/库的简要介绍及其优势: 1. Vanilla 定义:Vanilla 并不是一个框架,而是指 原生 JavaScript(即不使用任何框架或库)。优势…

Oracle 字符类型对比

本文以 Oracle12c 为例 1.主要区别对比 类型存储方式最大长度字符集支持适用场景备注​CHAR(M)固定长度空格填充2000 字节,M 代表字节长度默认字符集固定长度编码实际存储长度固定为定义长度(如 CHAR(10) 始终占 10 字节)​VARCHAR2(M)可变长…

阿里云操作系统控制台实战评测:提升云资源管理与监控效率

文章目录 前言产品介绍操作系统控制台体验阿里云操作系统开通 帮助与总结建议 前言 随着云计算和虚拟化技术的发展,操作系统控制台作为运维管理的核心工具之一,在现代IT环境中发挥着越来越重要的作用。它提供了一种更加直观、高效的方式来管理操作系统&…