当前位置: 首页 > news >正文

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; } }
http://www.rkmt.cn/news/128382.html

相关文章:

  • Java Web +线上教育培训办公系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】
  • +校园求职招聘系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
  • NPP 热带森林:巴拿马达连,1967-1968 年,R1
  • 【2025最新】基于SpringBoot+Vue的+校园求职招聘系统管理系统源码+MyBatis+MySQL
  • 计算机毕业设计springboot中国好山水 基于SpringBoot的“华夏山水行”旅游分享社区 SpringBoot驱动的“云游神州”自然风光互动平台
  • 智能宠物屋:AI Agent的宠物行为分析
  • 企业级+高校线上心理咨询室设计与实现pf管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】
  • Linly-Talker在电商直播中的潜力与落地场景
  • 只需一张照片!Linly-Talker打造专属AI数字人
  • 我停止使用 Docker 后,一切都变得更轻松了
  • 数字人直播切片:自动生成精彩片段用于二次传播
  • 学Simulink--风电电机控制场景实例:基于Simulink的DFIG网侧变流器单位功率因数控制仿真
  • 如何测试你的机器学习项目?初学者指南
  • 【wxWidgets教程】控件基础知识
  • 无需建模师!Linly-Talker让静态照片‘开口说话’
  • 性能提升 60%:前端性能优化终极指南
  • 如何用数据回答业务问题
  • 亲测10款降ai率工具:AI率80%怎么降低ai?(2025最新论文去AI味攻略)
  • Linly-Talker在公务员面试培训中的模拟考官应用
  • C++课后习题训练记录Day55
  • Linly-Talker vs 传统动画:效率提升90%的秘密
  • Linly-Talker生成视频的版权归属问题澄清
  • 掌握AI原生应用领域函数调用的核心要点
  • ARM Qt 字体过小的问题
  • 【C语言】之文件操作详解1(流,文件信息区,文件缓冲区,文件的打开与关闭)
  • 用Linly-Talker构建个性化AI助手,支持多端接入
  • 从零开始训练 LLM 需要多长时间?
  • 华为AI数据中心参考设计(附下载)
  • Linly-Talker唇形匹配误差低于8ms,达到行业领先水平
  • Linly-Talker音频后处理模块:提升清晰度与饱满度