news 2026/4/16 10:26:22

【HarmonyOS】个性化应用图标动态切换详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【HarmonyOS】个性化应用图标动态切换详解

在移动应用高度同质化的今天,图标早已不只是一个“入口”,而是用户对应用的第一印象。
在 HarmonyOS 生态中,系统能力不断下沉到应用层,开发者终于可以不再满足于“一个图标用到卸载”,而是让应用图标根据状态、主题或场景动态变化,成为真正“会表达”的界面元素。

本文将围绕HarmonyOS 中应用图标的个性化与动态切换能力展开,结合实际开发经验,介绍如何在不破坏系统规范的前提下,实现多图标配置、运行时切换以及典型应用场景设计,帮助应用在桌面层就建立清晰、直观的用户认知。

示例

开通服务

因目前功能还为beta阶段,所以需要申请开通服务。需按如下格式向华为运营人员发送邮件申请开通服务。申请审核时间为1-3个工作日,审核结果请关注邮件信息或互动中心通知。

  • 请确保申请开通图标管理服务的应用处于正式上架状态,避免服务开通失败。
  • 应用信息和开发者账号信息查询方法参见查看应用信息。

邮箱地址

agconnect@huawei.com

邮件标题

HarmonyOS应用图标管理开通申请-应用名称

邮件内容

开发者账号ID:

应用名称:

应用ID:

应用包名:

应用状态:

图标配置

开通图标管理服务后,登录AppGallery Connect,点击“APP与元服务”,在应用列表中选择已经开通图标管理服务的HarmonyOS应用,选择“分发 > 服务 > 图标管理“,进入图标管理页面,就可以管理HarmonyOS应用的个性化图标。

在图标管理页面点击“新增图标”按钮,进入创建图标页面。输入图标ID、图标名称,选择设备类型,上传图标文件,点击“保存”或者“提交”按钮,将图标保存为草稿状态或提交审核。

开发步骤

应用内可调用API查询到AGC配置的动态图标信息,用户点击切换可选的动态图标,系统切换对应的动态图标。当用户停止已选择的动态图标,可以再切换为默认图标。

查询动态图标信息

导入appInfoManager模块及相关公共模块。

import { appInfoManager } from '@kit.AppGalleryKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; import { BusinessError } from '@kit.BasicServicesKit';

调用queryDynamicIcons方法切换动态图标。

try { appInfoManager.queryDynamicIcons() .then((queryResult: appInfoManager.DynamicIconInfo[]) => { hilog.info(0, 'TAG', "Succeeded in getting DynamicIconInfo size = " + queryResult.length); for (let i = 0; i < queryResult.length; i++) { hilog.info(0, 'TAG', "Succeeded in getting DynamicIconInfo iconUrl = " + queryResult[i]["iconUrl"] + ", iconId = " + queryResult[i]["iconId"] + ", enabled = "+queryResult[i]["enabled"]); } }).catch((error: BusinessError) => { hilog.error(0, 'TAG', "queryDynamicIcons failed, code: " + error.code + ", exception message: " + error.message); }); } catch (error) { hilog.error(0, 'TAG', "queryDynamicIcons exception code: " + error.code + ", exception message: " + error.message); }

切换动态图标

导入appInfoManager模块及相关公共模块。

import { appInfoManager } from '@kit.AppGalleryKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; import { BusinessError } from '@kit.BasicServicesKit';

调用selectDynamicIcon方法切换动态图标。

try { let iconId: string = 'iconId'; appInfoManager.selectDynamicIcon(iconId).then(() => { hilog.info(0, 'TAG', "Succeeded in selecting dynamic icon"); }).catch((error: BusinessError) => { hilog.error(0, 'TAG', "selectDynamicIcon failed, code: " + error.code + ", exception message: " + error.message); }); } catch (error) { hilog.error(0, 'TAG', "selectDynamicIcon exception code: " + error.code + ", exception message: " + error.message); }

恢复默认图标

导入appInfoManager模块及相关公共模块。

import { appInfoManager } from '@kit.AppGalleryKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; import { BusinessError } from '@kit.BasicServicesKit';

调用disableDynamicIcon方法恢复默认图标。

try { appInfoManager.disableDynamicIcon().then(() => { hilog.info(0, 'TAG', "Succeeded in disabling dynamic icon"); }).catch((error: BusinessError) => { hilog.error(0, 'TAG', "disableDynamicIcon failed, code: " + error.code + ", exception message: " + error.message); }); } catch (error) { hilog.error(0, 'TAG', "disableDynamicIcon exception code: " + error.code + ", exception message: " + error.message); }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 22:52:58

新手学编程:C、Java、Python 场景对比与发展ys#12篇

SQLAlchemy是Python中最流行的ORM&#xff08;对象关系映射&#xff09;框架之一&#xff0c;它提供了高效且灵活的数据库操作方式。本文将介绍如何使用SQLAlchemy ORM进行数据库操作。目录 安装SQLAlchemy核心概念连接数据库定义数据模型创建数据库表基本CRUD操作查询数据关系…

作者头像 李华
网站建设 2026/4/11 2:52:23

EmotiVoice语音合成冷热数据分离存储方案

EmotiVoice语音合成冷热数据分离存储方案 在当今智能语音服务快速普及的背景下&#xff0c;用户对语音自然度和情感表达的要求已远超“能听清”这一基本需求。从虚拟主播的情绪化播报&#xff0c;到AI客服中带有温度的回应&#xff0c;再到游戏NPC根据剧情动态切换语气——这些…

作者头像 李华
网站建设 2026/4/15 19:04:48

C语言初学笔记2---C语言常见概念

目录 10.转义字符1.学习\\? → 在书写连续多个问号时使用&#xff0c;防止他们被解析成三字母词2.学习 \\ → 输出单个和多个单引号 2.1输出单个单引号2.2输出多个单引号 3.学习 \\" → 输出单个和多个双引号 "3.1输出单个双引号3.2输出多个双引号 4.学习\\\ → 表示…

作者头像 李华
网站建设 2026/4/14 16:29:45

《自动控制原理》第 5 章 频率响应分析法:5.3、5.4、5.5

5.3 控制系统频率特性图的绘制控制系统的频率特性可视为由典型环节频率特性组合而成的。本节将在上一节讨论的基础之上&#xff0c;介绍复杂控制系统频率特性图的绘制问题。一般来说&#xff0c;上节所介绍的典型环节频率特性图的绘制方法&#xff0c;可以推广至复杂控制系统。…

作者头像 李华
网站建设 2026/4/2 3:12:14

Java毕设项目:基于JAVA的北京市公交管理系统基于Java+Vue+SpringBoot的北京市公交管理系统(源码+文档,讲解、调试运行,定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华