Flutter

最近更新时间:2025-11-25 16:27:12

我的收藏
TUIKit Flutter 提供了强大的外观定制能力,支持自定义应用的主题模式(浅色/深色/跟随系统)和主题色。通过简单的配置,开发者可以轻松实现应用级别的主题切换和品牌色定制。
以消息列表为例,自定义主题模式和主题色的效果如下图所示:
浅色 + 默认颜色
浅色 + 橘黄色
深色 + 默认颜色
深色 + 绿色主题





核心能力

模式切换
浅色模式(Light):适合日间使用的明亮界面。
深色模式(Dark):适合夜间使用的暗色界面。
跟随系统(System):自动跟随系统外观设置。
主题色定制
预设主题色:提供蓝、绿、红、橙等标准色。
自定义主题色:支持任意 Hex 格式颜色。
智能色板生成:自动生成 10 个色阶的完整色板。
清除自定义:一键恢复默认主题色。

API 说明

以上功能基于 ThemeState 提供的一组简洁的 API,用于主题配置和信息查询。

设置主题模式

方法
参数
返回值
说明
setThemeMode
ThemeType
void
设置显示模式,自动保存并刷新。
ThemeType.SYSTEM:跟随系统外观。
ThemeType.LIGHT:强制使用浅色模式。
ThemeType.DARK:强制使用深色模式。

设置主题色

方法
参数
返回值
说明
setPrimaryColor
String
Unit
设置主题色,需要 Hex 格式(例如 "#1C66E5")。
clearPrimaryColor
Unit
清除自定义主题色,恢复默认蓝色。
说明:
调用 setThemeModesetPrimaryColor 后,配置会自动保存到持久化存储,无需手动保存。下次启动应用时会自动加载。
修改主题配置时会自动清除缓存,确保色彩方案实时更新。开发者无需关心缓存管理。
使用设置 API 时需避免频繁切换主题(例如在循环中调用)。

查询 ThemeState 信息

通过以下只读属性可以查询当前的主题配置状态和信息:
属性
类型
说明
currentMode
ThemeType
当前主题模式。
currentPrimaryColor
String?
当前主题色(Hex 格式)。
hasCustomPrimaryColor
Boolean
是否设置了自定义主题色。
isDarkMode
Boolean
当前是否为深色模式。

使用方式

本章节介绍如何在您的应用中集成和使用主题、主题色定制功能,按照从简单到复杂的顺序提供三种方式。

方式一:使用 AppBuilder 配置(推荐)

AppBuilder 是一个便捷式功能及 UI 自定义配置工具,通过 JSON 配置文件统一管理,适用于 Web + Native 双端应用需要保持统一外观的场景。
您可以在 Chat Web 体验馆 体验 AppBuilder 功能,体验入口:

虽然 Chat Web 体验馆上暂时无法实时观看移动端的配置效果,但移动端已经预先支持了 AppBuilder 的配置能力。
接下来为您介绍在 Web 体验馆设置 AppBuilder 后,如何在移动端项目中应用该自定义配置。操作步骤比较简单,只有 2 步:
1. 下载配置文件。
2. 将配置文件 appConfig.json 拖入您的 Flutter 项目中。
3. 在应用启动时加载配置文件。

步骤1:下载配置文件

访问 Chat Web 体验馆,下载配置文件 appConfig.json。下载路径为:

appConfig.json文件内容如下所示,与 AppBuilder 页面的配置项一一对应,与定义外观相关的配置是 theme及其子字段:
{
"theme": {
"mode": "light", // 主题模式,light-浅色模式,dark-深色模式,system-自动跟随系统
"primaryColor": "#E65100" // 主色调,16 进制颜色值
},
"messageList": {
"alignment": "two-sided",
"enableReadReceipt": false,
"messageActionList": [
"copy",
"recall",
"quote",
"forward",
"delete"
]
},
"conversationList": {
"enableCreateConversation": true,
"conversationActionList": [
"delete",
"mute",
"pin",
"markUnread"
]
},
"messageInput": {
"hideSendButton": false,
"attachmentPickerMode": "collapsed"
},
"search": {
"hideSearch": false
},
"avatar": {
"shape": "circular"
}
}
配置选项说明
参数说明
类型
可选值
说明
mode
String
"system""light""dark"
主题模式
primaryColor
String
Hex 颜色值,例如 "#0ABF77"
主题色

步骤2:将配置文件拖入项目中

将 appConfig.json 拖入您的项目中。以 GitHub 开源 Demo TUIKit Flutter 项目为例,appConfig.json 位于 demo 的 assets 文件夹下:

并在项目的 pubspec.yaml 文件中配置 assets 资源:
assets:
- assets/

步骤3:加载配置文件

请在您的应用启动时设置 JSON 文件路径,加载配置文件。
class _MyAppState extends State<MyApp> {
bool _isInitialized = false;

@override
void initState() {
super.initState();
_initializeApp();
}

Future<void> _initializeApp() async {
await StorageUtil.init();
await AppBuilder.init(configPath: 'packages/uikit_next/assets/appConfig.json');

if (mounted) {
setState(() {
_isInitialized = true;
});
}
}
}
至此,启动 App 后,TUIKit Flutter 组件的模式和主题色会自动显示成您在 appConfig.json 中设置的值。

方式二:代码设置主题模式

您可以通过 API setThemeMode 直接设置主题模式。示例代码如下所示:
val themeState = ThemeState.shared
Column {
Button(onClick = {
themeState.setThemeMode(ThemeMode.SYSTEM)
}) { Text(text = "跟随系统") }
Button(onClick = {
themeState.setThemeMode(ThemeMode.LIGHT)
}) { Text(text = "浅色模式") }
Button(onClick = {
themeState.setThemeMode(ThemeMode.DARK)
}) { Text(text = "深色模式") }
}

方式三:代码设置主题色

您可以通过 API setPrimaryColor 设置主题色,只需要传入一个主颜色值,整个 TUIKit Flutter 组件会自动根据该主颜色值,为不同的组件适配出一组相同色系里的相似色值渲染界面,您无需再手动适配界面 UI。示例代码如下所示:
final themeState = BaseThemeProvider.of(context);
themeState.setPrimaryColor('#1C66E5');
使用建议:
对于大多数应用,推荐使用 JSON 配置文件的方式,简单可靠且支持多端统一。
在整个应用中统一使用 themeState.colors 中的颜色,确保主题切换时界面保持一致。

常见问题

如何判断当前是否为深色模式?

if (themeState.isDarkMode) {
// 当前是深色模式
} else {
// 当前是浅色模式
}

可以设置透明度吗?

不支持。主题色只支持 6 位 Hex 格式(RGB),不支持 8 位格式(RGBA)。

如何恢复默认主题?

themeState.clearPrimaryColor() // 清除自定义主题色
themeState.setThemeMode(ThemeType.SYSTEM) // 恢复跟随系统

主题配置存储在哪里?

存储在应用的持久化存储中。应用卸载后会丢失,重新安装后恢复默认配置。

如何获取当前主题的完整配置?

final themeState = BaseThemeProvider.of(context);
final config = themeState.currentTheme;
print("模式: ${config.type}");
print("主题色: ${config.primaryColor ?? "默认"}");

可以同时设置模式和主题色吗?

可以分别调用两个方法,系统会自动合并配置:
themeState.setThemeMode(ThemeType.DARK)
themeState.setPrimaryColor("#0ABF77")