html5中如何实现贝赛尔曲线动画
发表于:2024-11-22 作者:千家信息网编辑
千家信息网最后更新 2024年11月22日,这篇文章主要介绍"html5中如何实现贝赛尔曲线动画"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"html5中如何实现贝赛尔曲线动画"文章能帮助大家解决问题。
千家信息网最后更新 2024年11月22日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安全错误
数据库的锁怎样保障安全
用什么软件进行数据库表设计
华为服务器硬盘低格
数据库长整型怎么表示
数据库中的关系是指什么
软件开发那个国家最强
怎么加qq宝可梦服务器
数据存储服务器简称
阅扑网络安全吗
网络安全和防火墙简介
数据库框架分享
软件开发对英语要求
南通工业网络技术常见问题
东莞市优普网络技术有限公司
2012数据库安装提示错误
连接路由器服务器无应响
长沙众元网络技术怎么样
河南数据软件开发设施价格优惠
泊头市晟杰网络技术服务有限公司
域服务器不能上网
ipfs服务器硬件组装
各村队签订网络安全承诺书
宜章县java数据库开发
向数组中插数据库
数据库程序员的意义
软件开发运行问题解决
海西州网络技术销售价格
软件开发的颁奖词
中富稻9水稻国家数据库
视频传输服务器
sql备份数据库 收缩