html5中如何实现贝赛尔曲线动画
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,这篇文章主要介绍"html5中如何实现贝赛尔曲线动画"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"html5中如何实现贝赛尔曲线动画"文章能帮助大家解决问题。
千家信息网最后更新 2025年11月08日html5中如何实现贝赛尔曲线动画
这篇文章主要介绍"html5中如何实现贝赛尔曲线动画"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"html5中如何实现贝赛尔曲线动画"文章能帮助大家解决问题。
二次贝赛尔曲线
/** * 二次贝塞尔曲线动画 * @param {Array} start 起点坐标 * @param {Array} 曲度点坐标(也就是转弯的点,不是准确的坐标,只是大致的方向) * @param {Array} end 终点坐标 * @param {number} percent 绘制百分比(0-100) */ function drawCurvePath(start, point, end, percent){ ctx.beginPath(); //开始画线 ctx.moveTo(start[0], start[1]); //画笔移动到起点 for (var t = 0; t <= percent / 100; t += 0.005) { //获取每个时间点的坐标 var x = quadraticBezier(start[0], point[0], end[0], t); var y = quadraticBezier(start[1], point[1], end[1], t); ctx.lineTo(x, y); //画出上个时间点到当前时间点的直线 } ctx.stroke(); //描边 } /** * 二次贝塞尔曲线方程 * @param {Array} start 起点 * @param {Array} 曲度点 * @param {Array} end 终点 * @param {number} 绘制进度(0-1) */ function quadraticBezier(p0, p1, p2, t) { var k = 1 - t; return k * k * p0 + 2 * (1 - t) * t * p1 + t * t * p2; } 放入完整的代码中:
二次贝塞尔曲线动画
动画就出来了
之前说了 drawCurvePath(start, point, end, percent)函数中point这个参数不是具体曲度的点,只是一个大致的方向
再开看一下 point改为[200,200]的情况
添加渐变
如果想实现坠落的效果,由高到低由远及近需要给线条加一个渐变的效果
/** * 创建线性渐变 * @param {Array} start 起点 * @param {Array} 曲度点 * @param {Array} end 终点 * @param {number} 绘制进度(0-1) */function createLinearGradient(start,end,startColor,endColor){ var lineGradient = ctx.createLinearGradient(...start, ...end); lineGradient.addColorStop(0, startColor); // lineGradient.addColorStop(0.3, '#fff'); lineGradient.addColorStop(1, endColor); return lineGradient}//draw函数需要做些调整function draw(){ //ctx.strokeStyle = '#ffffff'; ctx.strokeStyle = createLinearGradient(data.start, data.end, 'rgba(255,255,255,.2)', '#fff' ); //...} 头部光晕
添加头部光晕需要画一个圆,并设置径向渐变,利用drawCurvePath函数获取x,y并重置圆的位置
function createHeadLight(x,y){ ctx.beginPath(); //创建径向渐变 var radialGradient = ctx.createRadialGradient(x, y, 0, x, y, 20); radialGradient.addColorStop(0, "rgba(255,255,255,1)"); radialGradient.addColorStop(.2, "rgba(255,255,255,.8)"); radialGradient.addColorStop(1, "transparent"); ctx.fillStyle = radialGradient; //画圆 ctx.arc(x, y, 20, 0, 2 * Math.PI, false); ctx.fill();}//drawCurvePath函数需要做些调整function drawCurvePath(start, point, end, percent){ //... ctx.stroke(); //描边 createHeadLight(x,y) //和画线频率一样画圆 }添加文本
添加文本和添加头部光晕很相似,都是利用drawCurvePath函数获取x,y并重置文本块的位置
/** * 创建文本 * @param {String} 部门数据 * @param {Number} 数据 * @param {Number} x轴坐标 * @param {Number} y轴坐标 */function drawText(department, value, x, y) { ctx.fillStyle = '#fff' ctx.font = "22px 微软雅黑"; ctx.fillText(department, x + 30, y + 20); //为了使文本在光晕右下角x,y轴需要偏移一些距离 var width = ctx.measureText(value).width; //获取文本的宽度 ctx.fillStyle = createLinearGradient([x + 30, 0], //文本渐变x轴的渲染范围是[x+30,x+30+文本的宽度], [x + 30 + width, 0], //这里y取0,是因为没找到获取文本高的api,写0也是可以的 '#fffd00', '#ff6d00' ); ctx.fillText(value.toLocaleString(), x + 30, y + 50); } //drawCurvePath函数需要做些调整 function drawCurvePath(start, point, end, percent, department, value) { //... createHeadLight(x,y) drawText(department, value, x, y) }动画完成后结束位置添加文本和图片
动画完成后添加文本和图片需要注意下,曲线动画完成后需要立即清理画布,然后添加文本和图片
/** * 创建图片 * @param {Number} x轴坐标 * @param {Number} y轴坐标 */function drawImg(x, y) { ctx.drawImage(img, x - img.width / 2, y - img.height); }//draw 函数需要做些调整draw(){ //... if (percent <= 100) { requestAnimationFrame(draw); }else{ ctx.clearRect(0, 0, 1500, 750); //曲线动画完立即清除画布 drawText(data.department, //渲染文本 data.value, data.end[0], data.end[1]) drawImg(data.end[0], data.end[1]) //渲染图片 setTimeout(function(){ //2000ms后重绘 init() },2000) } }关于"html5中如何实现贝赛尔曲线动画"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
文本
动画
曲线
坐标
函数
图片
赛尔
曲度
起点
光晕
调整
位置
头部
数据
时间
画布
知识
终点
进度
贝塞
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发的分层
战双tap是什么服务器
黑群晖nas存储服务器
武汉运营网络安全维护资费
北京网络技术开发公司
微信后台服务器故障
宿州通信软件开发定制公司
数据库备份到另外一个服务器脚本
多玩魔兽 数据库
数据库 项目预算
象山嵌入式软件开发项目
高校校园网络安全问题成因
帝国时代3连接不了服务器
数据库语法记忆方法
国家安全网络安全教育
优质服务的软件开发公司
重要时节网络安全知识宣传
2012服务器系统安装进不去
中国商务部投资数据库
数据库恢复的冗余数据库
高校网络安全管理员的职责
阿里云数据库地址是哪个
win7数据库装不了
内网文件管理服务器hfs
单位网络安全吗
陇县软件开发兼职
魔兽世界阿拉希服务器去哪了
3g手机软件开发
如何做数据库设计
广州拼拼互联网科技有限公司