HarmonyOS 主题工具的实现(适用API12以上版本)

HarmonyOS 

import { ConfigurationConstant } from "@kit.AbilityKit"

export const ColorModeKey = 'interview-color-mode'

class Theme {
  /**
   * 初始化(持久化)
   */
  initTheme(){
     // 1. 持久化到本地(没有则创建, 有则无变化)
     PersistentStorage.persistProp(ColorModeKey, ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT)
     // 2. 从本地读取颜色模式
     const colorMode = AppStorage.get<ConfigurationConstant.ColorMode>(ColorModeKey)

     // 3. 存到本地 和 设置颜色模式
     this.setTheme(colorMode!)
  }

  setTheme(mode: ConfigurationConstant.ColorMode){
    // 更新本地存储的颜色模式
    AppStorage.setOrCreate<ConfigurationConstant.ColorMode>(ColorModeKey, mode)
    // 设置系统的颜色模式
    const ctx = AppStorage.get<Context>('context')
    if(ctx){
      ctx.getApplicationContext().setColorMode(mode)
    }
  }

  /**
   * 跟随系统
   */
  noSet(){
    this.setTheme(ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET)
  }


  /**
   * 设置深色
   */
  setDark(){
    this.setTheme(ConfigurationConstant.ColorMode.COLOR_MODE_DARK)
  }

  /**
   * 设置浅色
   */
  setLight(){
    this.setTheme(ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT)
  }
}

export const theme = new Theme()
 onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET);
    logger.info('Ability onCreate')
    //全局存储上下文
    AppStorage.setOrCreate('context', this.context)
    this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_DARK)
  }

调用方法

目标:实现主题设置,默认是亮色主题,可设置暗色主题,可以设置跟随系统

实现步骤:

  • 先让设置应用默认为亮色主题
  • 实现跟随系统颜色和亮色主题切换,实现暗色主题和亮色主题切换
  • 设置页显示是否开启暗黑模式

第一步:在首页

import { theme } from '../commons/utils'

theme.initTheme()

第二步:在弹窗页面接收系统状态

import { ColorModeKey } from "../commons/utils"

@StorageProp(ColorModeKey) colorMode: ConfigurationConstant.ColorMode =
    ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT
======================================================================================
//按钮
  Toggle({
          type: ToggleType.Switch,
          // 是否跟随系统模式
          isOn: this.colorMode === ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET
        })
          .onChange((val) => {
            if (val) {
              //TODO 跟随系统
              theme.noSet()
            } else {
              // TODO 默认亮色
              theme.setLight()
            }
          })
=====================================================================================
  //判断有没有开启跟随系统,跟随不开启,不跟随显示下面的选项
  if (this.colorMode !== ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET) {
  Row() {
          Text('普通模式')
          text('深色模式')
  }
}

第三步:设置里面显示已关闭和已开启

@StorageProp(ColorModeKey) colorMode: ConfigurationConstant.ColorMode =
    ConfigurationConstant.ColorMode.COLOR_MODE_LIGHT

 value: this.colorMode === ConfigurationConstant.ColorMode.COLOR_MODE_DARK ? '已开启' : '已关闭',
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值