news 2026/5/13 3:55:09

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/11 2:05:26

基于Linly-Talker开发虚拟偶像,成本降低超70%

基于Linly-Talker开发虚拟偶像&#xff0c;成本降低超70% 在直播带货的深夜直播间里&#xff0c;一个面容精致、语气亲切的“主播”正流畅地介绍商品——她不会疲倦&#xff0c;不需要休息&#xff0c;甚至连声音和表情都与真人无异。但你可能想不到&#xff0c;这样一个看似需…

作者头像 李华
网站建设 2026/5/10 9:41:25

Linly-Talker在博物馆导览中的沉浸式应用案例

Linly-Talker在博物馆导览中的沉浸式应用案例 在一座安静却人声鼎沸的博物馆展厅里&#xff0c;一位老人驻足于一尊斑驳的青铜器前&#xff0c;轻声问道&#xff1a;“这东西是哪个朝代的&#xff1f;”几秒钟后&#xff0c;屏幕上的虚拟讲解员微微启唇&#xff0c;眼神温和地回…

作者头像 李华
网站建设 2026/5/10 3:39:17

Linly-Talker支持竖屏视频输出吗?移动端适配方案

Linly-Talker支持竖屏视频输出吗&#xff1f;移动端适配方案 在短视频主导信息消费的今天&#xff0c;用户打开手机的第一件事&#xff0c;往往是刷一段全屏竖直的短视频。无论是抖音、快手还是微信视频号&#xff0c;9:16 的竖屏比例已经成为移动内容的标准形态。这种观看习惯…

作者头像 李华
网站建设 2026/5/10 8:07:44

智能宠物屋:AI Agent的宠物行为分析

智能宠物屋:AI Agent的宠物行为分析 关键词:智能宠物屋、AI Agent、宠物行为分析、计算机视觉、机器学习 摘要:本文聚焦于智能宠物屋中运用AI Agent进行宠物行为分析的技术。详细介绍了相关背景知识,包括目的、预期读者等。深入探讨了核心概念,如AI Agent和宠物行为分析的…

作者头像 李华
网站建设 2026/5/12 2:53:22

计算机毕业设计springboot中国好山水 基于SpringBoot的“华夏山水行”旅游分享社区 SpringBoot驱动的“云游神州”自然风光互动平台

计算机毕业设计springboot中国好山水go16ft9g &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。 当城市节奏越来越快&#xff0c;人们更渴望把周末和假期交给山川湖海。一款专注“…

作者头像 李华
网站建设 2026/5/11 12:31:21

Linly-Talker在公务员面试培训中的模拟考官应用

Linly-Talker在公务员面试培训中的模拟考官应用 在公务员考试竞争日益激烈的今天&#xff0c;面试环节的准备早已不再局限于“背模板”和“练套路”。越来越多考生意识到&#xff0c;真正的高分回答不仅需要内容扎实&#xff0c;更要在表达逻辑、情绪控制、临场反应等方面展现出…

作者头像 李华