JavaScript实现的贝塞尔曲线算法简单示例


Posted in Javascript onJanuary 30, 2018

本文实例讲述了JavaScript实现的贝塞尔曲线算法。分享给大家供大家参考,具体如下:

如果在HTML5支持好的浏览器中,可以看到用svg绘制的路径线。

在所有浏览器中,均可以看到一个小方块沿着贝塞尔曲线路径来回运动。

效果图:

JavaScript实现的贝塞尔曲线算法简单示例

主要代码:

<div style="position:absolute;left:0;top:0;width:500px;height:300px;overflow:hidden;">
<svg id="root" width="500" height="300" viewBox="0 0 500 300" xmlns="http://www.w3.org/2000/svg">
<title>svg</title>
<path d="M20,100 c80 -200 280 200 380 0 h-400" fill="none" stroke-width="1" stroke="gray" stroke-dasharray="3,3" />
</svg>
</div>
<div id="dotMove" style="position:absolute;width:6px;height:6px;overflow:hidden;background-color:#FF0000;"></div>
<script type="text/javascript">
/*
参考维基百科
http://zh.wikipedia.org/wiki/%E8%B2%9D%E8%8C%B2%E6%9B%B2%E7%B7%9A
*/
function Point2D(x,y){
  this.x=x||0.0;
  this.y=y||0.0;
}
/*
 cp在此是四??元素的?列:
 cp[0]?槠鹗键c,或上?D中的P0
 cp[1]?榈谝??控制?,或上?D中的P1
 cp[2]?榈诙??控制?,或上?D中的P2
 cp[3]?榻Y束?,或上?D中的P3
 t???抵担? <= t <= 1
*/
function PointOnCubicBezier( cp, t )
{
  var  ax, bx, cx;
  var  ay, by, cy;
  var  tSquared, tCubed;
  var  result = new Point2D ;
  /*?算多?式?S??/
  cx = 3.0 * (cp[1].x - cp[0].x);
  bx = 3.0 * (cp[2].x - cp[1].x) - cx;
  ax = cp[3].x - cp[0].x - cx - bx;
  cy = 3.0 * (cp[1].y - cp[0].y);
  by = 3.0 * (cp[2].y - cp[1].y) - cy;
  ay = cp[3].y - cp[0].y - cy - by;
  /*?算位於??抵?的曲??*/
  tSquared = t * t;
  tCubed = tSquared * t;
  result.x = (ax * tCubed) + (bx * tSquared) + (cx * t) + cp[0].x;
  result.y = (ay * tCubed) + (by * tSquared) + (cy * t) + cp[0].y;
  return result;
}
/*
 ComputeBezier以控制?cp所?生的曲??,填入Point2D???的?列。
 呼叫者必?分配足?虻挠????以供?出?果,其??lt;sizeof(Point2D) numberOfPoints>
*/
function ComputeBezier( cp, numberOfPoints, curve )
{
  var  dt;
  var  i;
  dt = 1.0 / ( numberOfPoints - 1 );
  for( i = 0; i < numberOfPoints; i++)
    curve[i] = PointOnCubicBezier( cp, i*dt );
}
var cp=[
  new Point2D(20, 0), new Point2D(100, 200), new Point2D(300, -200), new Point2D(400, 0)
];
var numberOfPoints=100;
var curve=[];
ComputeBezier( cp, numberOfPoints, curve );
var i=0, dot=document.getElementById("dotMove");
setInterval(function (){
  var j = (i<100)?i:(199-i);
  dot.style.left=curve[j].x+'px';
  dot.style.top=100-curve[j].y+'px';
  if(++i==200)i=0;
}, 50);
</script>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js实现顶部可折叠的菜单工具栏效果实例
May 09 Javascript
Javascript模仿淘宝信用评价实例(附源码)
Nov 26 Javascript
js实现人民币大写金额形式转换
Apr 27 Javascript
限制文本框只能输入数字||只能是数字和小数点||只能是整数和浮点数
May 27 Javascript
jQuery插件Validation快速完成表单验证的方式
Jul 28 Javascript
javascript之IE版本检测超简单方法
Aug 20 Javascript
详解如何用webpack打包一个网站应用项目
Jul 12 Javascript
Angularjs中ng-repeat的简单实例
Aug 25 Javascript
js实现数组和对象的深浅拷贝
Sep 30 Javascript
Bootstarp在pycharm中的安装及简单的使用方法
Apr 19 Javascript
封装微信小程序http拦截器过程解析
Aug 13 Javascript
基于JavaScript 实现拖放功能
Sep 12 Javascript
详解刷新页面vuex数据不消失和不跳转页面的解决
Jan 30 #Javascript
AngularJS双向数据绑定原理之$watch、$apply和$digest的应用
Jan 30 #Javascript
微信小程序数据存储与取值详解
Jan 30 #Javascript
Vue精简版风格概述
Jan 30 #Javascript
vue自定义全局组件(自定义插件)的用法
Jan 30 #Javascript
vue2.0之多页面的开发的示例
Jan 30 #Javascript
vue-cli实现多页面多路由的示例代码
Jan 30 #Javascript
You might like
PHP新手上路(六)
2006/10/09 PHP
PHP 读取和修改大文件的某行内容的代码
2009/10/30 PHP
php提交表单时判断 if($_POST[submit])与 if(isset($_POST[submit])) 的区别
2011/02/08 PHP
mysql 查询指定日期时间内sql语句实现原理与代码
2012/12/16 PHP
Yii2数据库操作常用方法小结
2017/05/04 PHP
Ubuntu彻底删除PHP7.0的方法
2018/07/27 PHP
JavaScript日历实现代码
2010/09/12 Javascript
jQuery 在光标定位的地方插入文字的插件
2012/05/10 Javascript
jquery 插件学习(四)
2012/08/06 Javascript
Jquery实现自定义弹窗示例
2014/03/12 Javascript
JQuery对表单元素的基本操作使用总结
2014/07/18 Javascript
JavaScript中具名函数的多种调用方式总结
2014/11/08 Javascript
jquery+ajax请求且带返回值的代码
2015/08/12 Javascript
Bootstrap Metronic完全响应式管理模板学习笔记
2016/07/08 Javascript
jQuery用noConflict代替$的实现方法
2017/04/12 jQuery
nodejs开发微信小程序实现密码加密
2017/07/11 NodeJs
详解React 16 中的异常处理
2017/07/28 Javascript
详解微信小程序Page中data数据操作和函数调用
2017/09/27 Javascript
你应该知道的几类npm依赖包管理详解
2017/10/06 Javascript
微信小程序bindinput与bindsubmit的区别实例分析
2019/04/17 Javascript
Vue实现数据请求拦截
2019/10/23 Javascript
python获取文件扩展名的方法
2015/07/06 Python
python数据分析数据标准化及离散化详解
2018/02/26 Python
python获取时间及时间格式转换问题实例代码详解
2018/12/06 Python
Python mutiprocessing多线程池pool操作示例
2019/01/30 Python
40个你可能不知道的Python技巧附代码
2020/01/29 Python
python 实现线程之间的通信示例
2020/02/14 Python
Java多态性的定义以及类型
2014/09/16 面试题
三年级音乐教学反思
2014/01/28 职场文书
应聘文员自荐信范文
2014/03/11 职场文书
2014各大专业毕业生自我评价
2014/09/17 职场文书
2015年房产经纪人工作总结
2015/05/15 职场文书
春风化雨观后感
2015/06/11 职场文书
2015初中政教处工作总结
2015/07/21 职场文书
基于python的matplotlib制作双Y轴图
2021/04/20 Python
 分享一个Python 遇到数据库超好用的模块
2022/04/06 Python