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

js 實現在2d平面上畫8的方法

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

效果如下:

js 在2d平面上畫8

實現這樣通過圓畫實現這樣一個8的形狀,首先我們要會畫圓。我們可以通過角度轉成弧度:

radian = angle/180 * Math.PI;

再通過弧度獲取當前的點的位置,這樣最基礎的圓的位置在-1到1的位置內

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

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

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>實現一個點在二維平面上面畫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 實現在2d平面上畫8的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關文章

  • 收集的比較全的automation服務器不能創(chuàng)建對象 異常原因和解決方法

    收集的比較全的automation服務器不能創(chuàng)建對象 異常原因和解決方法

    對于出現automation服務器不能創(chuàng)建對象的問題,下面有幾種解決方法大家可以試試。
    2008-10-10
  • 在VSCode中進行JavaScript調試的詳細流程

    在VSCode中進行JavaScript調試的詳細流程

    在JavaScript開發(fā)中,調試是一個關鍵的過程,它幫助我們理解和修復代碼中的問題,Visual Studio Code(VSCode)以其豐富的擴展和內置調試工具,為JavaScript開發(fā)者提供了強大的支持,本文將詳細介紹如何在VSCode中進行JavaScript調,需要的朋友可以參考下
    2024-07-07
  • 手機端轉盤抽獎代碼分享

    手機端轉盤抽獎代碼分享

    轉盤,也有一種說法叫抽獎轉盤,大體上是由一塊圓形的面板上面有很多的獎項設置,在圓形面板的前面,還有一根指針是固定的,下面,小編給大家分享手機端轉盤抽獎,需要的朋友可以參考下
    2015-09-09
  • VSCode開發(fā)TypeScript的實現步驟

    VSCode開發(fā)TypeScript的實現步驟

    本文主要介紹了VSCode開發(fā)TypeScript的實現步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Firefox getBoxObjectFor getBoundingClientRect聯系

    Firefox getBoxObjectFor getBoundingClientRect聯系

    Firefox在含有flash的網頁上提示:不建議使用 getBoxObjectFor() 。 請使用 element.getBoundingClientRect()。
    2008-10-10
  • 自己動手寫的javascript前端等待控件

    自己動手寫的javascript前端等待控件

    等待控件在網上搜有好多種,但是都很復雜,不一定用的順手,再說我的項目是bootstrap的原因,又不敢輕易使用第三方控件,怕不兼容,于是自己動手寫了個等待控件,有需要的朋友可以參考下
    2015-10-10
  • typescript枚舉的具體使用

    typescript枚舉的具體使用

    使用枚舉我們可以定義一些帶名字的常量,本文主要介紹了typescript枚舉的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • JavaScript高級程序設計 DOM學習筆記

    JavaScript高級程序設計 DOM學習筆記

    DOM是針對XML和HTML文檔的一個API:即規(guī)定了實現文本節(jié)點操控的屬性、方法,具體實現由各自瀏覽器實現。
    2011-09-09
  • 微信小程序實現井字棋游戲

    微信小程序實現井字棋游戲

    這篇文章主要為大家詳細介紹了微信小程序實現井字棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 設置iframe的document.designMode后僅Firefox中其body.innerHTML為br

    設置iframe的document.designMode后僅Firefox中其body.innerHTML為br

    設置iframe的document.designMode為On可以讓其可編輯,一般用在富文本編輯器組件中。這里僅列出各瀏覽器差異
    2012-02-02

最新評論