1、概述
ArkTs提供了应用内主题切换功能,支持全局主题切换,也支持局部主题切换,效果如下。本文针对主题切换做简朴介绍。
2、主题色
ArkTs提供了一套内置主题配色,有Colors对象持有,它包含了默认情况下,关于主题的基本资源枚举,枚举的key与说明如下:
- brand 品牌色。warning 一级警示色。alert 二级提示色。confirm 确认色。fontPrimary 一级文本字体颜色。fontSecondary 二级文本字体颜色。fontTertiary 三级文本字体颜色。fontFourth 四级文本字体颜色。fontEmphasize 高亮字体颜色。fontOnPrimary 一级文本反转颜色,用于彩色背景。fontOnSecondary 二级文本反转颜色,用于彩色背景。fontOnTertiary 三级文本反转颜色,用于彩色背景。fontOnFourth 四级文本反转颜色,用于彩色背景。iconPrimary 一级图标颜色。iconSecondary 二级图标颜色。iconTertiary 三级图标颜色。iconFourth 四级图标颜色。iconEmphasize 高亮图标颜色。iconSubEmphasize 高亮辅助图标颜色。iconOnPrimary 一级图标反转颜色,用于彩色背景。iconOnSecondary 二级图标反转颜色,用于彩色背景。iconOnTertiary 三级图标反转颜色,用于彩色背景。iconOnFourth 四级图标反转颜色,用于彩色背景。backgroundPrimary 一级背景颜色(实色,不透明)。backgroundSecondary 二级背景颜色(实色,不透明)。backgroundTertiary 三级背景颜色(实色,不透明)。backgroundFourth 四级背景颜色(实色,不透明)。backgroundEmphasize 高亮背景颜色(实色,不透明)。compForegroundPrimary 前背景。compBackgroundPrimary 白色背景。compBackgroundPrimaryTran 白色透明背景。compBackgroundPrimaryContrary 常亮背景。compBackgroundGray 灰色背景。compBackgroundSecondary 二级背景。compBackgroundTertiary 三级背景。compBackgroundEmphasize 高亮背景。compBackgroundNeutral 黑色中性高亮背景颜色。compEmphasizeSecondary 20%高亮背景颜色。compEmphasizeTertiary 10%高亮背景颜色。compDivider 通用分割线颜色。compCommonContrary 通用反转颜色。compBackgroundFocus 获焦态背景颜色。compFocusedPrimary 获焦态一级反转颜色。compFocusedSecondary 获焦态二级反转颜色。compFocusedTertiary 获焦态三级反转颜色。interactiveHover 通用悬停交互式颜色。interactivePressed 通用按压交互式颜色。interactiveFocus 通用获焦交互式颜色。interactiveActive 通用激活交互式颜色。interactiveSelect 通用选择交互式颜色。interactiveClick 通用点击交互式颜色。
复制代码 对应的颜色罗列如下:
Token场景类别LightDarktheme.colors.brand品牌色#ff0a59f7 data:image/s3,"s3://crabby-images/3183b/3183b1d73b1b500b04acb5b324b2dfd60e405b9a" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/cf70c/cf70cc650014587107a915f1ef149b112b7145ae" alt=""
theme.colors.warning一级警示色#ffe84026 data:image/s3,"s3://crabby-images/29323/2932365b30d48c20538c7bcee67ff801ebc8204d" alt=""
#ffd94838 data:image/s3,"s3://crabby-images/09437/09437351c0b06214f3dd7968ec047c74fd90f720" alt=""
theme.colors.alert二级警示色#ffed6f21 data:image/s3,"s3://crabby-images/2f8e5/2f8e5b3f0330faaa7ec4a9dc6df79c5e2bf1685c" alt=""
#ffdb6b42 data:image/s3,"s3://crabby-images/06907/06907ea8bbbc25dd130a0810c7841681c82287a8" alt=""
theme.colors.confirm确认色#ff64bb5c data:image/s3,"s3://crabby-images/bec5a/bec5a7bbbaedae355fbc123316924488cf4200ac" alt=""
#ff5ba854 data:image/s3,"s3://crabby-images/8811e/8811e7153aa29d87319852607d01621d103c8dc7" alt=""
theme.colors.fontPrimary一级文本#e5000000 data:image/s3,"s3://crabby-images/46a32/46a32ab5807f69fcca8c27c0ac74d4b87f4a5e95" alt=""
#e5ffffff data:image/s3,"s3://crabby-images/58719/587193b10ce16c12a94f03f12b0fddb05e6056ed" alt=""
theme.colors.fontSecondary二级文本#99000000 data:image/s3,"s3://crabby-images/234b2/234b219b205eb9f7ed491fcb1666b813e9f53d18" alt=""
#99ffffff data:image/s3,"s3://crabby-images/95804/958041e52c6851bc8145d91d91f35c9e9bfe32dc" alt=""
theme.colors.fontTertiary三级文本#66000000 data:image/s3,"s3://crabby-images/d4114/d41148f2fb5208096bd5d1f4df3b904b67be6a96" alt=""
#66ffffff data:image/s3,"s3://crabby-images/d1e33/d1e33525e6cbfac963a1d883943e1699791c5988" alt=""
theme.colors.fontFourth四级文本#33000000 data:image/s3,"s3://crabby-images/906d7/906d76fa69a9b5c1be95a374559e750107f9cf33" alt=""
#33ffffff data:image/s3,"s3://crabby-images/91536/91536d1307d8934fc506965c424cde6022e5a6ec" alt=""
theme.colors.fontEmphasize高亮文本#ff0a59f7 data:image/s3,"s3://crabby-images/80e3d/80e3dd2c55adb90189d9f61f616df68b53230865" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/7cb96/7cb961c3618b2b5ab76e4ba8116dbd70af4015c2" alt=""
theme.colors.fontOnPrimary一级文本反色#ffffffff data:image/s3,"s3://crabby-images/98c1c/98c1c2bf8c2d5e10cd552b7e068127d60883e8ed" alt=""
#ff000000 data:image/s3,"s3://crabby-images/d234c/d234c5b003ce473410bdbdb8a5d0b0b7e9b299d2" alt=""
theme.colors.fontOnSecondary二级文本反色#99ffffff data:image/s3,"s3://crabby-images/55220/55220fdaafe82b26dc27a49f93a390e8fc2faf89" alt=""
#99000000 data:image/s3,"s3://crabby-images/b0bea/b0beae081399bfe6c2b3aac012b9e11cb41d1588" alt=""
theme.colors.fontOnTertiary三级文本反色#66ffffff data:image/s3,"s3://crabby-images/dc8c7/dc8c70ffc4f0b5cf0372aa06930c09bb074efd10" alt=""
#66000000 data:image/s3,"s3://crabby-images/3f930/3f9309b3b08222ac05c5403a7faa6fb3eed3ee7b" alt=""
theme.colors.fontOnFourth四级文本反色#33ffffff data:image/s3,"s3://crabby-images/336ce/336cef268fe0cf3d9049e142375e92ff19e90850" alt=""
#33000000 data:image/s3,"s3://crabby-images/9e9a0/9e9a0f7378ad709883dd53da1e83ee7d6925f2e1" alt=""
theme.colors.iconPrimary一级图标#e5000000 data:image/s3,"s3://crabby-images/bec0e/bec0e4e2c5ecae41aa37d8782a608fda4b12ea5b" alt=""
#e5ffffff data:image/s3,"s3://crabby-images/748e3/748e35dea4c15934003423cf3af6809a83a70db5" alt=""
theme.colors.iconSecondary二级图标#99000000 data:image/s3,"s3://crabby-images/3d9eb/3d9ebf4f83b89d0ec9dd41a73bf5b26c2f41a086" alt=""
#99ffffff data:image/s3,"s3://crabby-images/e4978/e4978e48e93cb8ecf1b2931c3549349462afd84a" alt=""
theme.colors.iconTertiary三级图标#66000000 data:image/s3,"s3://crabby-images/b8112/b8112e111299a70b8691e17f8d82d67e03f070ae" alt=""
#66ffffff data:image/s3,"s3://crabby-images/8c6f6/8c6f60b51e9527a3297b44827f53afa66828cc75" alt=""
theme.colors.iconFourth四级图标#33000000 data:image/s3,"s3://crabby-images/b18d1/b18d19549647d9423822892c3b7136a1c5b8db72" alt=""
#33ffffff data:image/s3,"s3://crabby-images/7d1dc/7d1dce536cc9d6e26be5a8d74f2c6662fe3fdd1d" alt=""
theme.colors.iconEmphasize高亮图标#ff0a59f7 data:image/s3,"s3://crabby-images/c8bc6/c8bc6edab2190edafc29bdefe4d9d3beac17c094" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/e0523/e0523065c6dfad9668d6e9e07facd04cc7102497" alt=""
theme.colors.iconSubEmphasize高亮辅助图标#660a59f7 data:image/s3,"s3://crabby-images/a0664/a066484e0e443e076c57e87bbd42fb0bdf4fa083" alt=""
#66317af7 data:image/s3,"s3://crabby-images/09032/090328c2f4d3fd3e8e74a335d122dd1cb05f1502" alt=""
theme.colors.iconOnPrimary一级图标反色#ffffffff data:image/s3,"s3://crabby-images/4a059/4a059aa465065b78e7abbd1f98f03c95cefd7d0b" alt=""
#ff000000 data:image/s3,"s3://crabby-images/12497/124974ac1552c081bd42f5693f66749cfab681c8" alt=""
theme.colors.iconOnSecondary二级图标反色#99ffffff data:image/s3,"s3://crabby-images/83c7b/83c7b1c4a45f2b2e9b66e7dc01be464965e916a6" alt=""
#99000000 data:image/s3,"s3://crabby-images/8b8c0/8b8c05bf57693d398ed0585acc0816c205c3971c" alt=""
theme.colors.iconOnTertiary三级图标反色#66ffffff data:image/s3,"s3://crabby-images/197b9/197b940a4aefc0d74102dfb6a5e63617a704a685" alt=""
#66000000 data:image/s3,"s3://crabby-images/2dec9/2dec9e0b0977d756cc51d1f5e9800bd6e6955517" alt=""
theme.colors.iconOnFourth四级图标反色#33ffffff data:image/s3,"s3://crabby-images/03565/0356585f23687440b4e24d83cdd9eda2ab6ce30e" alt=""
#33000000 data:image/s3,"s3://crabby-images/a9cbd/a9cbdea7bf12e12e7ea3ada91de73557dc1af107" alt=""
theme.colors.backgroundPrimary一级配景(实色/不透明色)#ffffffff data:image/s3,"s3://crabby-images/7a8fa/7a8fafe8bbc1efb73a63669213207e811ada1f8d" alt=""
#ffe5e5e5 data:image/s3,"s3://crabby-images/31cbf/31cbf96ab5d5d8c61b90445d68366695501b872b" alt=""
theme.colors.backgroundSecondary二级配景(实色/不透明色)#fff1f3f5 data:image/s3,"s3://crabby-images/7c937/7c937a0afa6537d4e9df0dbabdf8dd8944f4ff2f" alt=""
#ff191a1c data:image/s3,"s3://crabby-images/521fb/521fb5ed31c9b2b6a58017e8aa9029a8daaaadc0" alt=""
theme.colors.backgroundTertiary三级配景(实色/不透明色)#ffe5e5ea data:image/s3,"s3://crabby-images/c3431/c343103dfa78d1004ac2af26cf452bef3b76512f" alt=""
#ff202224 data:image/s3,"s3://crabby-images/e27ed/e27edce68098d44ad424f45bc3d280d6651158bb" alt=""
theme.colors.backgroundFourth四级配景(实色/不透明色)#ffd1d1d6 data:image/s3,"s3://crabby-images/59024/59024c4619b8d7b05657887019c6d73ebe2fb270" alt=""
#ff2e3033 data:image/s3,"s3://crabby-images/80f25/80f25446bd8074cea3dae58bae841bccb298f57b" alt=""
theme.colors.backgroundEmphasize高亮配景(实色/不透明色)#ff0a59f7 data:image/s3,"s3://crabby-images/5bafd/5bafdb53616983433e2b2f668b6a76c428f66db2" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/2032b/2032bbdf34b17cdf0849e6cb506e1b7aab13e653" alt=""
theme.colors.compForegroundPrimary前配景#ff000000 data:image/s3,"s3://crabby-images/b757e/b757e2f1b9cd41490fc039300342c250dc0025df" alt=""
#ffe5e5e5 data:image/s3,"s3://crabby-images/5a941/5a9410186f6651a16ef70cb6e2752ae77ffacd37" alt=""
theme.colors.compBackgroundPrimary白色配景#ffffffff data:image/s3,"s3://crabby-images/21fc1/21fc1a6e715362335f1742c9d0d4751b1d5b75f1" alt=""
#ffffffff data:image/s3,"s3://crabby-images/5a379/5a37954727a7c9ac586d07d77d4b30fecb7115d0" alt=""
theme.colors.compBackgroundPrimaryTran白色透明配景#ffffffff data:image/s3,"s3://crabby-images/3ae71/3ae7104f58a9faa529e0c3c8e9e5d6e4e88b20fe" alt=""
#33ffffff data:image/s3,"s3://crabby-images/f7ec2/f7ec2ef8f1bb9a44f658b5e71c4547c86cd6edd7" alt=""
theme.colors.compBackgroundPrimaryContrary常亮配景#ffffffff data:image/s3,"s3://crabby-images/38bbb/38bbbd1833c581e3d5f85ff3bf5d458a9e2422e3" alt=""
#ffe5e5e5 data:image/s3,"s3://crabby-images/5a941/5a9410186f6651a16ef70cb6e2752ae77ffacd37" alt=""
theme.colors.compBackgroundGray灰色配景#fff1f3f5 data:image/s3,"s3://crabby-images/f3ec9/f3ec986e0fa08150a2362aef6458558452c02cbd" alt=""
#ffe5e5ea data:image/s3,"s3://crabby-images/c3431/c343103dfa78d1004ac2af26cf452bef3b76512f" alt=""
theme.colors.compBackgroundSecondary二级配景#19000000 data:image/s3,"s3://crabby-images/71280/712802bbed22b266a0a6a69da1fa3d8b33376c7d" alt=""
#19ffffff data:image/s3,"s3://crabby-images/17db8/17db868a45bff7960173b3c1db2af1bee16ad3df" alt=""
theme.colors.compBackgroundTertiary三级配景#0c000000 data:image/s3,"s3://crabby-images/98e26/98e267795644d51e0874fa75710d750c3d3cb4eb" alt=""
#0cffffff data:image/s3,"s3://crabby-images/f1c60/f1c60650691e7016c7de9e78eb1bd4aa5691baf8" alt=""
theme.colors.compBackgroundEmphasize高亮配景#ff0a59f7 data:image/s3,"s3://crabby-images/a7625/a762574d0f50572ffb6c2b1274f2ed493e319c56" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/701ef/701ef1a805ef47a3975a7cf3d221080d2106519b" alt=""
theme.colors.compBackgroundNeutral黑色中性高亮配景#ff000000 data:image/s3,"s3://crabby-images/9141f/9141f562702118fac321d572f3873f3ff6d31d8a" alt=""
#ffffffff data:image/s3,"s3://crabby-images/4b192/4b1923915c2d06bca416aefcc4e259f4e8d78486" alt=""
theme.colors.compEmphasizeSecondary20%高亮配景#330a59f7 data:image/s3,"s3://crabby-images/14271/142710c4565acc136e80fcf3c40a61ad61711d66" alt=""
#33317af7 data:image/s3,"s3://crabby-images/eb538/eb5389fc22da81a69428b6f9b3933cfc24eaabe0" alt=""
theme.colors.compEmphasizeTertiary10%高亮配景#190a59f7 data:image/s3,"s3://crabby-images/254c8/254c8a5184be5d16981142220c1153081a15ce4a" alt=""
#19317af7 data:image/s3,"s3://crabby-images/4b586/4b586f4995355695d09a7573a31baff970e502b9" alt=""
theme.colors.compDivider分割线颜色#33000000 data:image/s3,"s3://crabby-images/b91df/b91dffd56fdcc9b7ef0b002a9d4b08b1bb027203" alt=""
#33ffffff data:image/s3,"s3://crabby-images/f7ec2/f7ec2ef8f1bb9a44f658b5e71c4547c86cd6edd7" alt=""
theme.colors.compCommonContrary通用反色#ffffffff data:image/s3,"s3://crabby-images/4b192/4b1923915c2d06bca416aefcc4e259f4e8d78486" alt=""
#ff000000 data:image/s3,"s3://crabby-images/e5447/e5447f5275e1965b9cab8d58c552e917e97944bf" alt=""
theme.colors.compBackgroundFocus获焦态配景致#fff1f3f5 data:image/s3,"s3://crabby-images/f3ec9/f3ec986e0fa08150a2362aef6458558452c02cbd" alt=""
#ff000000 data:image/s3,"s3://crabby-images/f3ec9/f3ec986e0fa08150a2362aef6458558452c02cbd" alt=""
theme.colors.compFocusedPrimary获焦态一级反色#e5000000 data:image/s3,"s3://crabby-images/e40e6/e40e64bf2ac7c6c384b502a73bba76eca9c495f4" alt=""
#e5ffffff data:image/s3,"s3://crabby-images/aa2d7/aa2d7bf9741c10184142ac86008cd72cc1725d97" alt=""
theme.colors.compFocusedSecondary获焦态二级反色#99000000 data:image/s3,"s3://crabby-images/f7d52/f7d525462d1dba718175baf6fe9a395cc855cf3a" alt=""
#99ffffff data:image/s3,"s3://crabby-images/63123/63123d87c5d95e320495c77cbfdb9f17ebe99445" alt=""
theme.colors.compFocusedTertiary获焦态三级反色#66000000 data:image/s3,"s3://crabby-images/20695/206958ad54ea458b17f7eeffdc81c3cf7562da91" alt=""
#66ffffff data:image/s3,"s3://crabby-images/6091f/6091f9b508a0477756422564053f851817d824a5" alt=""
theme.colors.interactiveHover通用悬停交互式颜色#0c000000 data:image/s3,"s3://crabby-images/fdddd/fddddb8e884e097b130429852fd575fcc1554495" alt=""
#0cffffff data:image/s3,"s3://crabby-images/f1c60/f1c60650691e7016c7de9e78eb1bd4aa5691baf8" alt=""
theme.colors.interactivePressed通用按压交互式颜色#19000000 data:image/s3,"s3://crabby-images/1739b/1739b5e254b686c0a247119b9fc74a9be1dfb1f1" alt=""
#19ffffff data:image/s3,"s3://crabby-images/f819a/f819af3342e4b409ccaa7cd45aaa93c3c9239ed7" alt=""
theme.colors.interactiveFocus通用获焦交互式颜色#ff0a59f7 data:image/s3,"s3://crabby-images/6c455/6c4558c4e24e3e4bbb39db31d650030e83b10b85" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/881fa/881fad40112b11f23e2c7418901f624aa9eb16ab" alt=""
theme.colors.interactiveActive通用激活交互式颜色#ff0a59f7 data:image/s3,"s3://crabby-images/6c455/6c4558c4e24e3e4bbb39db31d650030e83b10b85" alt=""
#ff317af7 data:image/s3,"s3://crabby-images/881fa/881fad40112b11f23e2c7418901f624aa9eb16ab" alt=""
theme.colors.interactiveSelect通用选择交互式颜色#33000000 data:image/s3,"s3://crabby-images/e9105/e910586d4f091229619e49744277ea1e5d8d40af" alt=""
#33ffffff data:image/s3,"s3://crabby-images/f7ec2/f7ec2ef8f1bb9a44f658b5e71c4547c86cd6edd7" alt=""
theme.colors.interactiveClick通用点击交互式颜色#19000000 data:image/s3,"s3://crabby-images/1739b/1739b5e254b686c0a247119b9fc74a9be1dfb1f1" alt=""
#19ffffff data:image/s3,"s3://crabby-images/f819a/f819af3342e4b409ccaa7cd45aaa93c3c9239ed7" alt=""
我们可以在默认值的基础上对指定的颜色值做复写,别的部分将会使用默认值。假设我们需要修改几个颜色:brand、fontPrimary、iconOnPrimary、iconFourth,修改方法示意如下:
- // AppTheme.etsimport { CustomColors, CustomTheme } from '@kit.ArkUI'export class AppColors implements CustomColors { //自定义主题色 brand = 0xFF75D9; fontPrimary = 0xFFD53032 iconOnPrimary = 0xFFD53032 iconFourth = 0xFFD53032}export class AppTheme implements CustomTheme { public colors: AppColors = new AppColors()}export let gAppTheme: CustomTheme = new AppTheme()
复制代码
2.1、设置自定义全局主题
我们可以在UIAbility中设置ThemeControl,在onWindowStageCreate()方法中setDefaultTheme,设置应用内组件的自定义主题色。
代码如下(26行):
- // EntryAbility.etsimport {AbilityConstant, UIAbility, Want } from '@kit.AbilityKit';import { hilog } from '@kit.PerformanceAnalysisKit';import { window, CustomColors, ThemeControl } from '@kit.ArkUI';import { gAppTheme } from './AppTheme'export default class EntryAbility extends UIAbility { onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) { hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate'); } onDestroy() { hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy'); } onWindowStageCreate(windowStage: window.WindowStage) { // Main window is created, set main page for this ability hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); windowStage.loadContent('pages/Index', (err, data) => { if (err.code) { hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); return; } hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', JSON.stringify(data) ?? ''); // 在onWindowStageCreate()方法中setDefaultTheme ThemeControl.setDefaultTheme(gAppTheme) hilog.info(0x0000, 'testTag', '%{public}s', 'ThemeControl.setDefaultTheme done'); }); }}
复制代码
设置好后,我们写一个Page,代码如下:
- @Entry@Componentstruct DisplayPage { build() { Column() { List({ space: 10 }) { ListItem() { Column({ space: '5vp' }) { Text('Color mode') .margin({ top: '5vp', left: '14fp' }) .width('100%') Row() { Column() { Text('Light') .fontSize('16fp') .textAlign(TextAlign.Start) .alignSelf(ItemAlign.Center) Radio({ group: 'light or dark', value: 'light' }) .checked(true) } .width('50%') Column() { Text('Dark') .fontSize('16fp') .textAlign(TextAlign.Start) .alignSelf(ItemAlign.Center) Radio({ group: 'light or dark', value: 'dark' }) } .width('50%') } } .width('100%') .height('90vp') .borderRadius('10vp') } ListItem() { Column() { Text('Brightness') .width('100%') .margin({ top: '5vp', left: '14fp' }) Slider({ value: 40, max: 100 }) } .width('100%') .height('70vp') .borderRadius('10vp') } ListItem() { Column() { Row() { Column({ space: '5vp' }) { Text('Touch sensitivity') .fontSize('16fp') .textAlign(TextAlign.Start) .width('100%') Text('Increase the touch sensitivity of your screen' + ' for use with screen protectors') .fontSize('12fp') .fontColor(Color.Blue) .textAlign(TextAlign.Start) .width('100%') } .alignSelf(ItemAlign.Center) .margin({ left: '14fp' }) .width('75%') Toggle({ type: ToggleType.Switch, isOn: true }) .margin({ right: '14fp' }) .alignSelf(ItemAlign.Center) } .width('100%') .height('80vp') } .width('100%') .borderRadius('10vp') } } } .padding('10vp') .backgroundColor('#dcdcdc') .width('100%') .height('100%') }}
复制代码 效果如下(留意,在预览器里面看到的效果是默认主题效果,需要真机或模拟器才可以看到真实效果):
data:image/s3,"s3://crabby-images/f480a/f480a83dae1717b13e22e89f6f1bbcc897df4ce6" alt=""
默认情况下,效果如下:
data:image/s3,"s3://crabby-images/28bd1/28bd11a625787499df2ba5b81f2b87c9cb617b54" alt=""
2.3、Page中获取自定义主题
我们可以在onWillApplyTheme回调函数获取用于使自定义组件获取当前收效的Theme对象。我们可以获取自定义的主题对象,读取指定的主题色值,代码示例如下(9 ~ 10行):
- import { Theme, ThemeControl } from '@kit.ArkUI' @Entry @Component struct DisplayPage { @State menuItemColor: ResourceColor = $r('sys.color.background_primary') onWillApplyTheme(theme: Theme) { // theme是当前生效的主题对象 this.menuItemColor = theme.colors.backgroundPrimary; } build() { // ... } }
复制代码
2.4、局部应用主题色
我们可以通过设置WithTheme,将自定义主题Theme的配色应用于内部组件的默认样式。在WithTheme的作用范围内,组件的配色会根据Theme的配色举行调解。代码如下(29行):
- import { CustomColors, CustomTheme, Theme } from '@kit.ArkUI'class AppColors implements CustomColors { fontPrimary: Color = Color.Pink; backgroundEmphasize: Color = Color.Pink;}class AppColorsSec implements CustomColors { fontPrimary: Color = Color.Orange; backgroundEmphasize: Color = Color.Orange;}class AppTheme implements CustomTheme { public colors: AppColors = new AppColors()}class AppThemeSec implements CustomTheme { public colors: AppColors = new AppColorsSec()}@Entry@Componentstruct DisplayPage { @State customTheme: CustomTheme = new AppTheme() @State message: string = '切换自定义主题风格' count = 0; build() { WithTheme({ theme: this.customTheme }) { Row(){ Column() { Text('WithTheme') .fontSize(30) .margin({bottom: 10}) Text(this.message) .margin({bottom: 10}) Button('切换主题').onClick(() => { this.count++; if (this.count > 1) { this.count = 0; } switch (this.count) { case 0: this.customTheme = new AppTheme(); break; case 1: this.customTheme = new AppThemeSec(); break; } }) } .width('100%') } .height('100%') .width('100%') } }}
复制代码 如示例代码所示,使用WithTheme({ theme: this.myTheme })可将作用域内组件的配色设置为自定义主题风格。后续可以通过更新this.myTheme来更换主题风格。onWillApplyTheme回调函数用于使自定义组件能够获取当前收效的Theme对象。效果如下:
data:image/s3,"s3://crabby-images/6e713/6e71373963f2bff8e381e1ca730b656157cdac3c" alt=""
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |