html5中如何实现贝赛尔曲线动画
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,这篇文章主要介绍"html5中如何实现贝赛尔曲线动画"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"html5中如何实现贝赛尔曲线动画"文章能帮助大家解决问题。
千家信息网最后更新 2025年02月04日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安全错误
数据库的锁怎样保障安全
成都市网络安全产业规模
语音交友软件开发
本人30想学软件开发
做个网络安全员多少钱
江西软件开发企业
众创众惠互联网科技有限公司
徐汇区网络技术服务哪家好
u8如何用数据库进行备份
内蒙古驭驰互联网科技
戴尔服务器配置查询
aws服务器im
网络安全法非法搭建信道
收费站网络安全与维护
采用数据库技术处理数据
易优后台密码怎么在数据库修改
软件开发任务排期
戴尔服务器硬件检查
国开大专的计算机网络技术怎么样
HFC接入网络技术
服务器工作的步骤
云南五华区龙翔街软件开发
辽宁专业软件开发以客为尊
网络安全员证书考试内容
如何防备网络安全
上海智能网络技术开发行业标准
中国网络安全产业引领者
mongodb数据库分片
安徽服务器阵列卡安装云服务器
携程校招软件开发面试
甲方软件开发项目管理流程