【鸿蒙开发】适配深浅色模式

前言

当前系统存在深浅色两种显示模式,为了给用户更好的使用体验,应用应适配深浅色模式。

效果

深色模式效果

浅色模式效果

实现

首先我们需要设置软件跟随系统的模式来适配

kotlin 复制代码
this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET);

在深色模式的时候,系统会扫描resources下的dark目录下是否有对应的资源文件,用于深色模式。

在resources目录下的base和dark目录下分别设置不同的color资源(key保持一致)

base/element/color.json

json 复制代码
{
  "name": "nav_icon",
  "value": "#ffffff"
}

dark/element/color.json

json 复制代码
{
  "name": "nav_icon",
  "value": "#000000"
}

页面使用

scss 复制代码
Image(this.item.icon)
  .width(24)
  .height(24)
  .fillColor($r('app.color.nav_icon'))

因为name同名,不同模式下会取不同的色值, 这样我们就可以达到适配的目的

扩展

如果我们需要自己控制软件的模式如何去做呢?

准备图标

笔者从阿里巴巴矢量图标库找的svg图标

开发

监听颜色模式的变化

EntryAbility中新增onConfigurationUpdate事件,将颜色模式加到全局的AppStore

javascript 复制代码
onCreate() {
    AppStorage.setOrCreate('colorMode', this.context.config.colorMode);
}

onConfigurationUpdate(newConfig: Configuration): void {
  AppStorage.set('colorMode', newConfig.colorMode);
}

页面开发

scss 复制代码
@StorageProp('colorMode') colorMode: ConfigurationConstant.ColorMode =
  ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET;


Image(this.colorMode === ConfigurationConstant.ColorMode.COLOR_MODE_DARK ? $r('app.media.dark') :
$r('app.media.light'))
  .width(20)
  .height(20)
  .onClick(() => {
    this.getUIContext()
      .getHostContext()?.getApplicationContext().setColorMode(this.colorMode ===
    ConfigurationConstant.ColorMode.COLOR_MODE_DARK ? ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT :
    ConfigurationConstant.ColorMode.COLOR_MODE_DARK);
  })
  .position({
    left: 16,
    bottom: 16,
  });

效果

相关推荐
kyriewen12 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒12 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮12 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦13 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer13 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队13 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY13 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_13 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏14 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站14 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控