欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實現(xiàn)的貝塞爾曲線算法簡單示例

 更新時間:2018年01月30日 12:16:43   作者:cuixiping  
這篇文章主要介紹了JavaScript實現(xiàn)的貝塞爾曲線算法,結(jié)合簡單實例形式分析了基于javascript的貝塞爾曲線算法的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下

本文實例講述了JavaScript實現(xiàn)的貝塞爾曲線算法。分享給大家供大家參考,具體如下:

如果在HTML5支持好的瀏覽器中,可以看到用svg繪制的路徑線。

在所有瀏覽器中,均可以看到一個小方塊沿著貝塞爾曲線路徑來回運動。

效果圖:

主要代碼:

<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]為起始點,或上圖中的P0
 cp[1]為第一個控制點,或上圖中的P1
 cp[2]為第二個控制點,或上圖中的P2
 cp[3]為結(jié)束點,或上圖中的P3
 t為參數(shù)值,0 <= t <= 1
*/
function PointOnCubicBezier( cp, t )
{
  var  ax, bx, cx;
  var  ay, by, cy;
  var  tSquared, tCubed;
  var  result = new Point2D ;
  /*計算多項式係數(shù)*/
  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;
  /*計算位於參數(shù)值t的曲線點*/
  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所產(chǎn)生的曲線點,填入Point2D結(jié)構(gòu)的陣列。
 呼叫者必須分配足夠的記憶體以供輸出結(jié)果,其為<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>

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學運算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)

希望本文所述對大家JavaScript程序設計有所幫助。

相關(guān)文章

  • 對layui中的onevent 和event的使用詳解

    對layui中的onevent 和event的使用詳解

    今天小編就為大家分享一篇對layui中的onevent 和event的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • uni-app應用配置manifest.json最全最詳細配置

    uni-app應用配置manifest.json最全最詳細配置

    這篇文章主要給大家介紹了關(guān)于uni-app應用配置manifest.json最全最詳細配置,manifest.json文件是UniApp開發(fā)中用來配置應用信息的重要文件,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • 顯示js對象所有屬性和方法的函數(shù)

    顯示js對象所有屬性和方法的函數(shù)

    顯示js對象所有屬性和方法,從網(wǎng)上整理了不少,大家可以看下原理都是差不多的。
    2009-10-10
  • html的DOM中Event對象onabort事件用法實例

    html的DOM中Event對象onabort事件用法實例

    這篇文章主要介紹了html的DOM中Event對象onabort事件用法,實例分析了onabort事件的適用范圍與對應的javascript使用技巧,需要的朋友可以參考下
    2015-01-01
  • 微信小程序?qū)崿F(xiàn)底部導航

    微信小程序?qū)崿F(xiàn)底部導航

    這篇文章主要為大家詳細介紹了微信小程序自定義底部導航,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 瀏覽器窗口加載和大小改變事件示例

    瀏覽器窗口加載和大小改變事件示例

    這篇文章主要介紹了瀏覽器窗口加載和大小改變事件,需要的朋友可以參考下
    2014-02-02
  • 最新熱門腳本Autojs源碼分享

    最新熱門腳本Autojs源碼分享

    AutoJS 是基于一個標準字典庫的文本輸入自動完成 JavaScript 庫。Auto.js 是使用純 JS 實現(xiàn)的,沒有任務外部依賴,大小僅僅 6kb,本文給大家分享最新熱門腳本Autojs源碼,感興趣的朋友一起看看吧
    2021-05-05
  • 微信小程序跨頁面?zhèn)鬟fdata數(shù)據(jù)方法解析

    微信小程序跨頁面?zhèn)鬟fdata數(shù)據(jù)方法解析

    這篇文章主要介紹了微信小程序跨頁面?zhèn)鬟fdata數(shù)據(jù)方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • 使用Turn.js實現(xiàn)翻書效果的完整步驟

    使用Turn.js實現(xiàn)翻書效果的完整步驟

    最近項目經(jīng)理我個項目練練手,其項目需求是要實現(xiàn)翻書效果,下面這篇文章主要給大家介紹了關(guān)于使用Turn.js實現(xiàn)翻書效果的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • js date 格式化

    js date 格式化

    本文將以yyyy-MM-dd HH:mm:ss為例介紹js date 格式化的相關(guān)知識。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02

最新評論