news 2026/5/5 1:03:16

Hanzi Writer 是 javascript 免费开源库,根据汉字书写时按照笔画顺序的特征,可以播放正确笔画顺序的描边动画和练习测试。 支持简体字和繁体字

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Hanzi Writer 是 javascript 免费开源库,根据汉字书写时按照笔画顺序的特征,可以播放正确笔画顺序的描边动画和练习测试。 支持简体字和繁体字

官网:Hanzi Writer

文档:Hanzi Writer

Hanzi Writer 是 javascript 免费开源库,根据汉字书写时按照笔画顺序的特征,可以播放正确笔画顺序的描边动画和练习测试。 支持简体字和繁体字。我基于这个库制作了汉字学习项目:汉字学习:汉字学习 主要针对小学语文的汉字学习,可以学习汉字的书写笔画,拼音等。 - AtomGit | GitCode

安装

在 script 标签加载 Hanzi Writer

最简单选项是直接从 jsdelivr CDN 加载 Hanzi Writer JS 。只需将以下内容放入你的网页的头部:

<script src="https://cdn.jsdelivr.net/npm/hanzi-writer@3.0/dist/hanzi-writer.min.js"></script>

也可以拷贝一个下载 Hanzi Writer javascript 文件:
hanzi-writer.min.js- 生产压缩版 (32 kb, 9kb 压缩后的)
hanzi-writer.js- 开发未压缩版本 (72 kb)

上面的脚本将在脚本加载后使全局HanziWriter变量可用。

比如我在汉字学习这个软件里面,index.html文件中这样用的:

<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>小学生汉字学习练习软件</title> <link rel="stylesheet" href="style.css"> <script src="https://cdn.jsdelivr.net/npm/hanzi-writer@3.5/dist/hanzi-writer.min.js"></script> </head> <body>

通过 npm 加载 Hanzi Writer

如果你想在 webpack 或 node.js 中包含 Hanzi Writer,你可以从npm install hanzi-writer安装。

npm install hanzi-writer

然后,可以在你的代码中包含 Hanzi Writer

const HanziWriter = require('hanzi-writer');

基本使用

在屏幕上渲染

创建一个新的HanziWriter实例需要传入一个目标 div (ID 或者 DOM 引用),你要渲染的汉字, 配置选项. 下面举例说明一个简单的例子。在 HTML 中声明以下内容:

<div id="character-target-div"></div>

然后, 在 Javascript:

var writer = HanziWriter.create('character-target-div', '我', { width: 100, height: 100, padding: 5 });

你能看到以下结果:

在上面的示例中,width和height是包含字符的框的大小(以像素为单位),padding是字符和框边缘之间的空格,也以像素为单位 你也可以配置其他选项,例如角色的颜色。下面是使用不同尺寸和颜色绘制的示例:

var writer = HanziWriter.create('character-target-div', '爽', { width: 150, height: 150, padding: 20, strokeColor: '#EE00FF' // pink });

Hanzi Writer 也支持给汉字的偏旁部首上设置不同的颜色。 你可以用radicalColor选项来设置来展示的部手颜色. 下面的以 草 字为例给偏旁部首添加绿色。

var writer = HanziWriter.create('character-target-div', '草', { width: 150, height: 150, padding: 5, radicalColor: '#168F16' // green });

动画

当你创建了一个 Hanzi Writer 实例后,你可以调用animateCharacter()方法来让它运动. 在下面的例子中, 点击按钮可以让汉字运动。这个 HTML 代码看起来是下面这个样子:

<div id="character-target-div"></div> <button id="animate-button">动画</button>

Then, the corresponding javascript:

var writer = HanziWriter.create('character-target-div', '国', { width: 100, height: 100, padding: 5, showOutline: true }); document.getElementById('animate-button').addEventListener('click', function() { writer.animateCharacter(); });

实践

在汉字学习这个项目中,是这样使用的,script.js文件代码:

createWriter(containerId, character, isPractice = false) { const container = document.getElementById(containerId); container.innerHTML = ''; // 清除之前的内容 const writerConfig = { width: isPractice ? 200 : 150, height: isPractice ? 200 : 150, padding: isPractice ? 20 : 10, showOutline: true, strokeColor: '#333333', radicalColor: '#168F16' }; try { const writer = HanziWriter.create(container, character, writerConfig); if (isPractice) { this.practiceWriter = writer; } else { this.writer = writer; } return writer; } catch (error) { console.warn(`无法创建${character}的动画实例: ${error.message}`); // 创建一个简单的占位符 container.innerHTML = `<div class="placeholder-writer">${character}</div>`; container.style.display = 'flex'; container.style.justifyContent = 'center'; container.style.alignItems = 'center'; container.style.fontSize = isPractice ? '120px' : '100px'; container.style.color = '#333333'; return null; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 9:16:03

中小企业如何低成本搭建数字人服务?Linly-Talker实战案例

中小企业如何低成本搭建数字人服务&#xff1f;Linly-Talker实战案例 在电商直播间里&#xff0c;一个虚拟主播正用标准普通话介绍新款智能手表&#xff0c;口型与语音完美同步&#xff1b;在企业官网角落&#xff0c;一位“客服专员”微笑着回应访客提问&#xff0c;语气亲切、…

作者头像 李华
网站建设 2026/5/1 6:57:01

NPP 热带森林:巴拿马达连,1967-1968 年,R1

NPP Tropical Forest: Darien, Panama, 1967-1968, R1 简介 该净初级生产力&#xff08;NPP&#xff09;数据集包含一个 ASCII 文件&#xff08;.txt 格式&#xff09;。数据文件包含巴拿马达连省拉拉河&#xff08;雨季样地&#xff09;和萨瓦纳河&#xff08;旱季样地&…

作者头像 李华
网站建设 2026/5/3 8:36:16

计算机毕业设计springboot软件学院体育设备管理系统 基于SpringBoot的软件学院体育器材全生命周期管理平台 软件学院智慧体育资产运营系统的设计与实现

计算机毕业设计springboot软件学院体育设备管理系统hf2xd446 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。软件学院的体育馆、健身房、户外场地每天人头攒动&#xff0c;篮球、…

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

【wxWidgets教程】控件基础知识

控件是构成界面的基本元素&#xff0c;也是wxWidgets的主体。优秀的工程师不仅要像神农遍尝百草了解药性那样熟悉各类控件的特性&#xff0c;还要像医生给病人开处方那样针对不同的应用特点合理搭配各类控件以满足多样化的客户需求&#xff0c;“譬之若良医疗病&#xff0c;病万…

作者头像 李华
网站建设 2026/5/1 10:11:03

如何评估短期技术债务对长期发展的影响?有哪些量化指标?

要评估短期技术债务对长期发展的影响&#xff0c;需从量化指标&#xff08;可衡量的客观数据&#xff09;和定性影响&#xff08;对长期竞争力的间接冲击&#xff09;两方面入手。短期技术债务&#xff08;如为快速交付而牺牲的代码质量、架构妥协、测试不足等&#xff09;若未…

作者头像 李华
网站建设 2026/5/1 11:19:02

ARM Qt 字体过小的问题

文章目录1、环境介绍2、问题3、解决4、参考文章5、总结1、环境介绍 板卡&#xff1a;T113、buildroot 系统 Qt 版本&#xff1a;Qt 5.15.9 2、问题 在 Ubuntu 编译运行时&#xff0c;看起来挺正常的&#xff0c;但部署到板卡后发现&#xff0c;字体莫名其妙变小了。这主要是…

作者头像 李华