• Home
Name Date Size #Lines LOC

..--

etc/para/12-May-2024-6151

figures/12-May-2024-

interfaces/kits/napi/12-May-2024-367298

sa_profile/12-May-2024-3330

services/12-May-2024-838576

test/12-May-2024-285176

.clang-formatD12-May-20243 KiB107106

BUILD.gnD12-May-2024889 2822

CODEOWNERSD12-May-2024755 1514

LICENSED12-May-20249.9 KiB177150

OAT.xmlD12-May-20243.8 KiB6311

README_zh.mdD12-May-20242.9 KiB6539

bundle.jsonD12-May-20241 KiB5151

README_zh.md

1# 用户界面外观
2
3
4## 简介
5
6**内容介绍**:该仓用于管理和配置系统的用户界面外观(例如深色模式),不包括产品化应用定制的外观模式(例如桌面的简易模式)。目前用户界面外观仅支持深色模式服务,提供了系统应用API,用于获取和设置系统的深浅色模式,同时可持久化保存当前配置的深浅色模式参数。
7
8**架构图**:
9
10![](figures/uiAppearance-architecture_zh.png)
11
12如上图所示,系统应用(setting)调用提供的API配置深浅色模式,用户界面外观(ui appearance)通知元能力服务(Ability Manager Service,AMS)更新配置,遍历所有APP进程。在此期间,AMS会通知资源管理(resoure manager)切换应用的限定词目录,同时通知窗口管理服务(Window Manager Service,WMS)配置更新。之后,WMS会进一步通知ArkUI(ace engine)主动刷新资源,待资源刷新完成后用户界面外观服务会持久化存储当前配置的系统参数(system param)。
13
14
15## 目录
16
17深色模式服务源代码在/foundation/arkui/ui\_appearance下,目录结构如下图所示:
18
19```
20/foundation/arkui/ui_appearance
21├── etc
22│   └── para             # 持久化配置文件存放目录
23│── interfaces/kits
24│   └── napi             # napi接口存放目录
25│── sa_profile           # 深色模式系统服务的配置文件
26│── services             # 深色模式系统服务实现
27├── test                 # 接口单元测试
28```
29
30
31## 使用场景
32
33仅支持具有ohos.permission.UPDATE_CONFIGURATION权限的系统应用通过API接口控制和切换当前用户界面的外观模式。
34
35
36## 说明
37
38### 接口说明
39
40| 接口名 | 描述 |
41| -------- | -------- |
42| setDarkMode(mode: DarkMode, callback: AsyncCallback\<void\>): void | 设置用户界面模式(深色或浅色),Callback方式。 |
43| setDarkMode(mode: DarkMode): Promise\<void\> | 设置用户界面模式(深色或浅色),Promise方式。 |
44| getDarkMode(): DarkMode | 获取当前用户界面模式(深色或浅色)。 |
45
46### 使用说明
47
48功能模块开发指导可参考[**开发指南**](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis/js-apis-uiappearance.md)
49
50### 编译命令
51
52全量编译命令参考[**编译构建指导**](https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/subsystems/subsys-build-all.md),单独编译ui_appearance部件命令如下:
53```
54./build.sh --product-name {product_name} --ccache --build-target ui_appearance_packages
55```
56
57## 相关仓
58
59[ArkUI框架子系统](https://gitee.com/openharmony/docs/blob/master/zh-cn/readme/ArkUI%E6%A1%86%E6%9E%B6%E5%AD%90%E7%B3%BB%E7%BB%9F.md)
60
61[arkui\_napi](https://gitee.com/openharmony/arkui_napi)
62
63[arkui\_ace\_engine](https://gitee.com/openharmony/arkui_ace_engine/blob/master/README_zh.md)
64
65**arkui\_ui\_appearance**