国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

基于js Canvas實現(xiàn)二次貝塞爾曲線

2024-05-06 16:47:17
字體:
供稿:網(wǎng)友

本文實例為大家分享了js Canvas實現(xiàn)二次貝塞爾曲線的具體代碼,供大家參考,具體內(nèi)容如下

先上效果圖:

js,Canvas,貝塞爾曲線

實現(xiàn)代碼:

<!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坐標(biāo) * @param sy 起始點y坐標(biāo) * @param ex 結(jié)束點x坐標(biāo) * @param ey 結(jié)束點y坐標(biāo) * @param cx 控制點x坐標(biāo) * @param cy 控制點y坐標(biāo) * @param part 將起始點到控制點的線段分成的份數(shù),數(shù)值越高,計算出的曲線越精確 */ 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; // 控制點到結(jié)束點的x和y每次的增量 var changeX2 = (ex - cx) / part; var changeY2 = (ey - cy) / part;  for(var i = 0; i < part; i++) { // 計算兩個動點的坐標(biāo) var qx1 = sx + changeX1 * i; var qy1 = sy + changeY1 * i; var qx2 = cx + changeX2 * i; var qy2 = cy + changeY2 * i; // 計算得到此時的一個貝塞爾曲線上的點坐標(biāo) 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>

上面的是靜態(tài)的,來個動態(tài)的看一看:

<!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坐標(biāo) * @param sy 起始點y坐標(biāo) * @param ex 結(jié)束點x坐標(biāo) * @param ey 結(jié)束點y坐標(biāo) * @param cx 控制點x坐標(biāo) * @param cy 控制點y坐標(biāo) * @param part 將起始點到控制點的線段分成的份數(shù),數(shù)值越高,計算出的曲線越精確 * @param interval 畫圖的間隔 * @return function 調(diào)用一次就向后畫一段曲線 */ 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; // 控制點到結(jié)束點的x和y每次的增量 var changeX2 = (ex - cx) / part; var changeY2 = (ey - cy) / part; // 上次的點坐標(biāo) var lastX = sx; var lastY = sy;  var i = 0;  return function () { // 計算兩個動點的坐標(biāo) 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; // 從上次的點繼續(xù)畫 ctx.beginPath(); ctx.moveTo(lastX, lastY); ctx.lineTo(bx, by); ctx.stroke(); // 保存點坐標(biāo) 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>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 红安县| 清河县| 镇雄县| 灌阳县| 普陀区| 密云县| 聂拉木县| 偃师市| 宣威市| 二连浩特市| 枣庄市| 克东县| 化德县| 黎川县| 荣成市| 确山县| 郁南县| 左权县| 澄城县| 南漳县| 兰州市| 香港| 宜城市| 怀仁县| 奉化市| 施甸县| 容城县| 连城县| 昭觉县| 大荔县| 大新县| 舞钢市| 三明市| 亳州市| 株洲县| 辽阳市| 宜宾县| 西盟| 溧水县| 福安市| 卢湾区|