基于js Canvas实现二次贝塞尔曲线
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要为大家详细介绍了基于js Canvas实现二次贝塞尔曲线,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了js Canvas实现二次贝塞尔曲线的具体代码,供大家参考,具体内容如下
先上效果图
实现代码
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>二次贝塞尔曲线</title> <meta name="Keywords" content=""> <meta name="Description" content=""> <style type="text/css"> body, h1{margin:0;} canvas{margin: 20px; } </style> </head> <body> <h1>二次贝塞尔曲线</h1> <canvas id="canvas" width=600 height=600 style="border: 1px solid #c;"></canvas> <script> / @param sx 起始点x坐标 @param sy 起始点y坐标 @param ex 结束点x坐标 @param ey 结束点y坐标 @param cx 控制点x坐标 @param cy 控制点y坐标 @param part 将起始点到控制点的线段分成的份数,数值越高,计算出的曲线越精确 / function draw(sx, sy, ex, ey, cx, cy, part) { var canvas = document.getElementById('canvas'); var ctx = canvas.getContext('2d'); //绘制起始点、控制点、终点 ctx.beginPath(); ctx.moveTo(sx, sy); ctx.lineTo(cx, cy); ctx.lineTo(ex, ey); ctx.stroke(); // 绘制二次贝塞尔曲线 ctx.beginPath(); ctx.moveTo(sx, sy); // 起始点到控制点的x和y每次的增量 var changeX1 = (cx - sx) / part; var changeY1 = (cy - sy) / part; // 控制点到结束点的x和y每次的增量 var changeX2 = (ex - cx) / part; var changeY2 = (ey - cy) / part; for(var i = 0; i < part; i++) { // 计算两个动点的坐标 var qx1 = sx + changeX1 i; var qy1 = sy + changeY1 i; var qx2 = cx + changeX2 i; var qy2 = cy + changeY2 i; // 计算得到此时的一个贝塞尔曲线上的点坐标 var bx = qx1 + (qx2 - qx1) i / part; var by = qy1 + (qy2 - qy1) i / part; ctx.lineTo(bx, by); } ctx.stroke(); } window.onload = function () { draw(0, 0, 600, 0, 150, 450, 100); }; </script> </body> </html>
上面的是静态的,来个动态的看一看
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>二次贝塞尔曲线</title> <meta name="Keywords" content=""> <meta name="Description" content=""> <style type="text/css"> body, h1{margin:0;} canvas{margin: 20px; } </style> </head> <body> <h1>二次贝塞尔曲线</h1> <canvas id="canvas" width=600 height=600 style="border: 1px solid #c;"></canvas> <script> / @param sx 起始点x坐标 @param sy 起始点y坐标 @param ex 结束点x坐标 @param ey 结束点y坐标 @param cx 控制点x坐标 @param cy 控制点y坐标 @param part 将起始点到控制点的线段分成的份数,数值越高,计算出的曲线越精确 @param interval 画图的间隔 @return function 调用一次就向后画一段曲线 / function draw(sx, sy, ex, ey, cx, cy, part, interval) { var canvas = document.getElementById('canvas'); var ctx = canvas.getContext('2d'); //绘制起始点、控制点、终点 ctx.beginPath(); ctx.moveTo(sx, sy); ctx.lineTo(cx, cy); ctx.lineTo(ex, ey); ctx.stroke(); // 绘制二次贝塞尔曲线 ctx.beginPath(); ctx.moveTo(sx, sy); // 起始点到控制点的x和y每次的增量 var changeX1 = (cx - sx) / part; var changeY1 = (cy - sy) / part; // 控制点到结束点的x和y每次的增量 var changeX2 = (ex - cx) / part; var changeY2 = (ey - cy) / part; // 上次的点坐标 var lastX = sx; var lastY = sy; var i = 0; return function () { // 计算两个动点的坐标 var qx1 = sx + changeX1 i; var qy1 = sy + changeY1 i; var qx2 = cx + changeX2 i; var qy2 = cy + changeY2 i; // 计算得到此时的一个贝塞尔曲线上的点 var bx = qx1 + (qx2 - qx1) i / part; var by = qy1 + (qy2 - qy1) i / part; // 从上次的点继续画 ctx.beginPath(); ctx.moveTo(lastX, lastY); ctx.lineTo(bx, by); ctx.stroke(); // 保存点坐标 lastX = bx; lastY = by; i += 1; if (i < part) { setTimeout(arguments.callee, interval); } } } window.onload = function () { var display = draw(0, 0, 600, 0, 150, 450, 200, 50); display(); }; </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指