开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 382|回复: 22
收起左侧

[易源码分享] 标准的自适应主题例子 【JadeView V2】

[复制链接]
结帖率:80% (8/10)
发表于 昨天 21:44 | 显示全部楼层 |阅读模式   甘肃省兰州市
分享源码
界面截图:
是否带模块: -
备注说明: -
本帖最后由 荼泱 于 2026-5-16 22:06 编辑

JadeView V2

JadeView 主题切换方案文档

JadeView V2

JadeView V2 开发文档

一、实现原理

采用 前端下发指令 + 后端控制主题 + 前端监听内核事件 的解耦架构,核心流程如下:

  1. 前端仅负责发送主题切换指令(light/dark/system),不直接修改页面样式
  2. 后端(Rust/C++)通过内核 API 修改窗口 PreferredColorScheme
  3. WebView2 内核感知主题变更后,自动触发 prefers-color-scheme 媒体cha询事件;
  4. 前端唯一监听该事件,根据内核真实状态同步页面样式,实现全局主题统一。

核心设计:后端控权、前端响应,彻底解耦前后端样式逻辑,避免状态不一致。

二、前端核心 API(IPC 调用)

1. setWindowTheme

功能:设置窗口主题(浅色/深色/跟随系统)
调用方式

await jade.invoke('setWindowTheme', { theme: "Light" | "Dark" | "System" });

参数说明

  • theme:字符串,可选值 Light(浅色)、Dark(深色)、System(跟随系统)

2. setTitlebarOverlayStyle

功能:适配主题,设置标题栏覆盖层样式(图标颜色、悬浮背景)
调用方式

await jade.invoke('setTitlebarOverlayStyle', {
  height: -1,
  icon_color: "#FFFFFF" | "#1E1E1E",
  hover_bg: "#33333380" | "#DCDCDC80"
});

参数说明

  • height:数字,固定传 -1(自适应)
  • icon_color:字符串,图标颜色(深色模式用白色、浅色模式用深色)
  • hover_bg:字符串,悬浮背景色(带透明度)

3. 内核事件监听

功能:感知 WebView2 内核真实主题状态,同步页面样式
使用方式

// 初始化媒体cha询对象
const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)');

// 监听主题变更事件
mediaQuery.addEventListener('change', (e) => {
  const isDark = e.matches;
  // 唯一入口:根据内核状态更新页面样式(如添加/移除 .dark 类)
  document.documentElement.classList.toggle('dark', isDark);
});

// 初始化执行一次,同步初始状态
mediaQuery.dispatchEvent(new Event('change'));

三、后端对接要点(Rust/C++)

1. 注册 IPC 处理器

通过 register_ipc_handler 绑定前端调用的 setWindowThemesetTitlebarOverlayStyle 方法,接收前端指令。

2. 窗口主题设置

调用内核接口 set_window_theme(window_id, theme),传入窗口 ID 和主题参数(Light/Dark/System),修改系统级窗口主题。

3. 事件转发

确保 JadeView  内核将主题变更事件正常转发到前端,触发前端 prefers-color-scheme 监听回调。

四、关键设计优势

  • 解耦清晰:前后端各司其职,无样式逻辑交叉;
  • 状态一致:以内核真实状态为唯一标准,避免前后端状态错位;
  • 易扩展:新增主题或样式时,仅需修改前端监听逻辑,无需改动后端核心;
  • 适配原生:贴合系统原生主题机制,体验一致。

源码下载:

本例子由Ai驱动开发,仅易语言手动适配
Python 与 易语言


游客,如果您要查看本帖隐藏内容请回复

签到天数: 5 天

发表于 3 分钟前 | 显示全部楼层   广西壮族自治区百色市
6666666666666
回复 支持 反对

使用道具 举报

结帖率:80% (4/5)

签到天数: 1 天

发表于 1 小时前 | 显示全部楼层   山东省潍坊市
已经顶贴,感谢您对论坛的支持!
回复 支持 反对

使用道具 举报

结帖率:100% (26/26)

签到天数: 13 天

发表于 1 小时前 | 显示全部楼层   广东省揭阳市
看不明白,等于说要会写html才行是不
回复 支持 反对

使用道具 举报

结帖率:100% (26/26)

签到天数: 13 天

发表于 1 小时前 | 显示全部楼层   广东省揭阳市
看看是啥东东
回复 支持 反对

使用道具 举报

签到天数: 17 天

发表于 3 小时前 | 显示全部楼层   湖北省鄂州市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)

签到天数: 9 天

发表于 3 小时前 | 显示全部楼层   广东省广州市
666谢谢分享
回复 支持 反对

使用道具 举报

发表于 3 小时前 | 显示全部楼层   辽宁省沈阳市
  感谢分享
回复 支持 反对

使用道具 举报

结帖率:67% (2/3)

签到天数: 15 天

发表于 4 小时前 | 显示全部楼层   福建省泉州市
6666666666666661
回复 支持 反对

使用道具 举报

签到天数: 14 天

发表于 4 小时前 | 显示全部楼层   江苏省淮安市
谢谢分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表