亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js 實(shí)現(xiàn)在2d平面上畫8的方法

 更新時(shí)間:2018年10月10日 09:37:37   作者:專注前端30年  
今天小編就為大家分享一篇js 實(shí)現(xiàn)在2d平面上畫8的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

效果如下:

js 在2d平面上畫8

實(shí)現(xiàn)這樣通過(guò)圓畫實(shí)現(xiàn)這樣一個(gè)8的形狀,首先我們要會(huì)畫圓。我們可以通過(guò)角度轉(zhuǎn)成弧度:

radian = angle/180 * Math.PI;

再通過(guò)弧度獲取當(dāng)前的點(diǎn)的位置,這樣最基礎(chǔ)的圓的位置在-1到1的位置內(nèi)

var x = Math.sin(radian);
var y = Math.cos(radian);

當(dāng)畫完一個(gè)完整的圓以后,另一個(gè)圓的x軸繪制和當(dāng)前的x軸的位置是相同的,但是y軸需要改變,所以,我們就判斷一下,是否畫完一整個(gè)圓(畫完一整個(gè)8需要720度),如果大于360度,就代表當(dāng)前正在繪制的是第二個(gè)圓,所以,在繪制第二個(gè)圓的時(shí)候,我們調(diào)整一下y的位置,這樣就實(shí)現(xiàn)的兩個(gè)圓的繪制:

if(angle%720 > 360){
 y = -y+2;
}

案例代碼

<!doctype html>
<html>
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>實(shí)現(xiàn)一個(gè)點(diǎn)在二維平面上面畫8</title>
 <style>
  #canvas{
   display: block;
   margin:0 auto;
  }
 </style>
</head>
<body>
<canvas id="canvas" width="300" height="600"></canvas>
</body>
<script>
var canvas = document.querySelector("#canvas");
var ctx = canvas.getContext("2d");
var angle = 0; //角度
var radian = 0; //弧度
function draw() {
 angle += 2;
 radian = angle/180 * Math.PI;
 var x = Math.sin(radian);
 var y = Math.cos(radian);

 if(angle%720 > 360){
  y = -y+2;
 }

 var left = x*150+150;
 var top = y*150+150;

 ctx.arc(left, top, 1, 0, Math.PI*2);

 ctx.strokeStyle = "green";

 ctx.stroke();

 requestAnimationFrame(draw);
}

requestAnimationFrame(draw);
</script>
</html>

以上這篇js 實(shí)現(xiàn)在2d平面上畫8的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關(guān)文章

最新評(píng)論