基于js Canvas实现二次贝塞尔曲线


Posted in Javascript onDecember 25, 2018

本文实例为大家分享了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 #ccc;"></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 #ccc;"></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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
window.showModalDialog使用手册
Jan 11 Javascript
根据地区不同显示时间的javascript代码
Aug 13 Javascript
使用jquery给input和textarea设定ie中的focus
May 29 Javascript
js no-repeat写法 背景不重复
Mar 18 Javascript
JS中批量给元素绑定事件过程中的相关问题使用闭包解决
Apr 15 Javascript
Js实现手机发送验证码时按钮延迟操作
Jun 20 Javascript
jQuery选择器源码解读(三):tokenize方法
Mar 31 Javascript
javascript格式化日期时间方法汇总
Jun 19 Javascript
JavaScript中Math对象的方法介绍
Jan 05 Javascript
js简易版购物车功能
Jun 17 Javascript
vue路由对不同界面进行传参及跳转的总结
Apr 20 Javascript
使用JS实现动态时钟
Mar 12 Javascript
JavaScript实现小球沿正弦曲线运动
Sep 07 #Javascript
微信小程序使用二次贝塞尔曲线画波浪
Dec 25 #Javascript
微信小程序开发问题之wx.previewImage
Dec 25 #Javascript
微信小程序使用for循环动态渲染页面操作示例
Dec 25 #Javascript
JavaScript简单实现动态改变HTML内容的方法示例
Dec 25 #Javascript
使用gulp构建前端自动化的方法示例
Dec 25 #Javascript
JavaScript实现的级联算法示例【省市二级联动功能】
Dec 25 #Javascript
You might like
TMDPHP 模板引擎使用教程
2012/03/13 PHP
PHP中CURL方法curl_setopt()函数的参数分享
2013/01/19 PHP
Apache中php.ini的设置方法
2013/02/28 PHP
完美解决在ThinkPHP控制器中命名空间的问题
2017/05/05 PHP
PHP Beanstalkd消息队列的安装与使用方法实例详解
2020/02/21 PHP
javascript椭圆旋转相册实现代码
2012/01/16 Javascript
禁止选中文字兼容IE、Chrome、FF等
2013/09/04 Javascript
js动态添加事件并可传参数示例代码
2013/10/21 Javascript
JS获取html对象的几种方式介绍
2013/12/05 Javascript
javascript动态判断html元素并执行不同的操作
2014/06/16 Javascript
jquery插件validation实现验证身份证号等
2015/06/04 Javascript
浅谈JavaScript 的执行顺序
2015/08/07 Javascript
在JavaScript中模拟类(class)及类的继承关系
2016/05/20 Javascript
Javascript中级语法快速入手
2016/07/30 Javascript
jQuery实现jQuery-form.js实现异步上传文件
2017/04/28 jQuery
easyui下拉框动态级联加载的示例代码
2017/11/29 Javascript
JavaScript实现的DOM绘制柱状图效果示例
2018/08/08 Javascript
vue src动态加载请求获取图片的方法
2018/10/17 Javascript
基于Vue中使用节流Lodash throttle详解
2019/10/30 Javascript
基于Vue实现微前端的示例代码
2020/04/24 Javascript
解决Ant Design Modal内嵌Form表单initialValue值不动态更新问题
2020/10/29 Javascript
Django中间件基础用法详解
2019/07/18 Python
python使用openCV遍历文件夹里所有视频文件并保存成图片
2020/01/14 Python
Python获取、格式化当前时间日期的方法
2020/02/10 Python
CSS3实现千变万化的文字阴影text-shadow效果设计
2016/04/26 HTML / CSS
JINS眼镜官方网站:日本最大的眼镜邮购
2016/10/14 全球购物
EVE LOM英国官网:全世界最好的洁面膏
2017/10/30 全球购物
UNIX文件名称有什么规定
2013/03/25 面试题
音乐学院硕士生的自我评价分享
2013/11/01 职场文书
轻金属冶金专业毕业生自荐信
2013/11/02 职场文书
个人简历中的自我评价怎么写
2014/01/26 职场文书
《植物妈妈有办法》教学反思
2014/02/25 职场文书
市场营销方案范文
2014/03/11 职场文书
保护水资源的标语
2014/06/17 职场文书
假释思想汇报范文
2014/10/11 职场文书
Python中非常使用的6种基本变量的操作与技巧
2022/03/22 Python