Flutter for OpenHarmony: Flutter 三方库 icon_font_generator 自动化将 SVG 图标集转化为字体文件(鸿蒙矢量资源全自动管理)

Flutter for OpenHarmony: Flutter 三方库 icon_font_generator 自动化将 SVG 图标集转化为字体文件(鸿蒙矢量资源全自动管理)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net

请添加图片描述

前言

在 OpenHarmony 应用中,为了保证在不同分辨率屏幕(手机、折叠屏、平板)下图标都能保持绝对清晰,且为了减小 HAP 包体积,使用“字体图标”取代“位图图片”是业界公认的标准方案。

icon_font_generator 是一个强大的命令行工具。它能将一整组 SVG 图标自动打包成一个 .ttf 字体文件,并同步生成 Dart 类。开发者只需关注 SVG 文件的增删,剩余的同步工作全部自动化。

一、全自动构建链路

命令行扫描

强类型访问

assets/ohos_icons/*.svg (原始素材)

icon_font_generator

assets/fonts/OhosIcons.ttf (单字体文件)

lib/generated/ohos_icons.dart (自动生成类)

鸿蒙 Flutter UI

在鸿蒙开发中,我们绝不推荐手写 IconData 的内存地址。通过以下流程,可以实现资产的自动化转换:

1. 准备 SVG 素材

将设计师导出的 .svg 图标文件统一放入工程资产目录:

  • 存储路径:assets/ohos_icons/*.svg

2. 执行自动化构建指令

在项目根目录运行以下命令,工具会自动扫描 SVG、生成字体文件并创建 Dart 调用类:

# 💡 核心指令:一键生成鸿蒙图标资产 flutter pub run icon_font_generator \ --from=assets/ohos_icons \ --to=assets/fonts/OhosIcons.ttf \ --out=lib/generated/ohos_icons.dart \ --class-name=OhosIcons 

3. 在 pubspec.yaml 中注册

生成的 .ttf 必须在配置文件中声明方可生效:

flutter:fonts:-family: OhosIcons fonts:-asset: assets/fonts/OhosIcons.ttf 

二、核心 API 实战

2.1 字体图标基础加载

通过工具生成的静态变量,你可以像使用 Icons.home 一样访问自定义图标,无需记忆十六进制代码。

// 💡 核心 API: 访问生成的自定义图标 (OhosIcons 为自动生成的类)Icon(OhosIcons.home, size:24, color:Colors.blue)
在这里插入图片描述

2.2 自定义图标样式

字体图标本质上是文本。它们可以完美支持颜色叠加、阴影、渐变以及混合模式。

// 💡 核心 API: 为字体图标添加特定的阴影效果Icon(OhosIcons.scanner, shadows:[Shadow(color:Colors.black26, offset:Offset(0,4), blurRadius:10)],)
在这里插入图片描述

2.3 动态映射图标

当图标选择来自后端(如后台配置的任务列表)时,配合 Map 映射表,可以极大地简化业务逻辑。

// 💡 核心 API: 建立 API 响应与字体图标的动态映射staticconstMap<String,IconData> iconMapping ={'home':OhosIcons.home,'user':OhosIcons.person,};
在这里插入图片描述

三、OpenHarmony 平台适配

3.1 资产注册注意

在鸿蒙工程中,生成的 .ttf 文件必须在 pubspec.yamlfonts 节点下正确声明,且 family 名称必须与生成的 Dart 代码中 fontFamily 固定值完全匹配,否则会出现显示为“方块(乱码)”的问题。

3.2 高刷性能优势

💡 提示:相比于加载大量的 .png 图片导致鸿蒙设备主线程解码压力过大,字体图标加载极为迅速。在滑动长列表(如金刚区菜单)时,字体图标几乎不会造成任何掉帧(Jank)。

四、完整实战示例:鸿蒙风格图标资产中心

本示例演示如何通过模拟生成的 OhosIcons 类构建一套标准的鸿蒙金刚区菜单系统。

classOhosIconMenuextendsStatelessWidget{@overrideWidgetbuild(BuildContext context){returnGridView.count( crossAxisCount:4, children:[_buildItem(OhosIcons.scanner,"扫一扫"),_buildItem(OhosIcons.payment,"钱包"),_buildItem(OhosIcons.message,"行程"),_buildItem(OhosIcons.settings,"更多"),],);}Widget_buildItem(IconData icon,String label){returnColumn( children:[// 💡 字体图标加载性能极佳Icon(icon, color:Colors.blueAccent, size:30),Text(label, style:TextStyle(fontSize:12)),],);}}
在这里插入图片描述

五、总结

icon_font_generator 将 OpenHarmony 应用的资源管理提升到了自动化水平。它通过单一字体文件解决了碎片化图片的管理难题,不仅极大地优化了应用的运行性能,还统一了 UI 层的调用标准。对于任何追求极致轻量化和视觉一致性的鸿蒙项目,这都是一套必选的基本建设。

Read more

人工智能、机器学习和深度学习,其实不是一回事

人工智能、机器学习和深度学习,其实不是一回事

一、人工智能、机器学习与深度学习的真正区别 在当今科技领域,我们经常听到人工智能、机器学习和深度学习这三个词。它们虽然相关,但含义不同。 1.1 人工智能 人工智能是计算机科学的一个分支,旨在研究如何合成与分析能够像人一样行动的计算主体。简单来说,AI 的目标是利用计算机来模拟甚至替代人类大脑的功能。 一个理想的 AI 系统通常具备以下特征:像人一样思考、像人一样行动、理性地思考与行动。 1.2 机器学习 机器学习是实现人工智能的一种途径。它的核心定义是:赋予计算机在没有被显式编程的情况下进行学习的能力。 与传统的基于规则的编程不同,机器学习不依赖程序员手写每一条逻辑指令,而是通过算法让机器从大量数据中寻找规律,从而对新的数据产生预测或判断。 1.3 深度学习 深度学习是机器学习的一种特殊方法,也称为深度神经网络。它受人类大脑结构的启发,通过设计多层的神经元网络结构,来模拟万事万物的特征表示。 1.4 三者之间的层级关系 厘清这三者的关系对于初学者至关重要。人工智能 AI是最宏大的概念,包含了所有让机器变聪明的技术。机器学习 ML是 AI

By Ne0inhk

91代码神器:AI如何帮你自动生成高质量代码

快速体验 1. 打开 InsCode(快马)平台 https://www.inscode.net 2. 点击'项目生成'按钮,等待项目生成完整后预览效果 输入框内输入如下内容: 使用91代码平台,创建一个能够自动生成Python爬虫代码的AI助手。要求:1. 输入目标网站URL后自动分析页面结构;2. 根据分析结果生成可运行的爬虫代码;3. 支持反爬虫机制处理;4. 输出结构化数据存储方案。使用Kimi-K2模型实现智能代码生成,并确保代码包含必要的注释和异常处理。 最近尝试用AI工具自动生成Python爬虫代码,发现整个过程比想象中高效。通过91代码平台的Kimi-K2模型,只需要简单几步就能完成从页面分析到完整爬虫的生成。这里分享下具体实现过程和实际体验。 1. 输入目标网站URL 在平台对话框直接粘贴需要爬取的网址,比如某个电商商品页面。AI会先自动检测网页结构特征,识别出关键数据区域(如商品标题、价格、评论区块等),这步相当于人工查看网页源码的自动化版本。 2. 智能生成基础爬虫框架 根据分析结果,AI会生成包含Requests或Sel

By Ne0inhk
Claude Code安装与使用完全指南:2026 年最前沿的 AI 编程助手

Claude Code安装与使用完全指南:2026 年最前沿的 AI 编程助手

文章目录 * 前言 * 一、什么是 Claude Code? * 1.1 定义与定位 * 1.2 技术优势 * 二、安装前的环境准备 * 2.1 系统要求 * 2.2 前置依赖 * 三、Claude Code 全平台安装教程 * 3.1 安装方式对比 * 3.2 Windows 系统安装 * 3.3 macOS 系统安装 * 3.5 安装后初始化 * 四、配置与优化 * 4.1 配置文件位置 * 4.2 跳过新手引导 * 4.3 接入国产大模型(免翻墙方案)

By Ne0inhk
Flutter 三方库 mediapipe_core 的鸿蒙化适配指南 - 实现高性能的端侧 AI 推理库集成、支持多维视觉任务与手势/表情识别实战

Flutter 三方库 mediapipe_core 的鸿蒙化适配指南 - 实现高性能的端侧 AI 推理库集成、支持多维视觉任务与手势/表情识别实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 mediapipe_core 的鸿蒙化适配指南 - 实现高性能的端侧 AI 推理库集成、支持多维视觉任务与手势/表情识别实战 前言 在进行 Flutter for OpenHarmony 的智能化应用开发时,集成强大的机器学习(ML)能力是打造差异化体验的关键。mediapipe_core 是谷歌 MediaPipe 框架在 Dart 侧的核心封装库。它能让你在鸿蒙真机上实现极其流畅的人脸检测、手势追踪以及实时姿态估计。本文将深入探讨如何在鸿蒙系统下构建低功耗、高响应的端侧 AI 推理链路。 一、原原理性解析 / 概念介绍 1.1 基础原理 mediapipe_core 作为 MediaPipe 的“神经中枢”

By Ne0inhk