美文网首页
利用canvas简单制作一个转动的圆

利用canvas简单制作一个转动的圆

作者: 神永夜 | 来源:发表于2016-07-21 10:48 被阅读0次
<!DOCTYPE html>

<html>

<head>

  <title>round.html</title>

  <style type="text/css">

    #canvas {

      background:#dddddd;

    }

  </style>

  <script type="text/javascript">

    var canvas=null;

    var ctx=null;

    //参数

    var r=10;//小圆半径

    var number=6;//圆形层数

    var number2=9;//最里层的小圆的数量

    var direction=0;//旋转方向

    var startAngle=0;

    function init() {

      canvas=document.getElementById("canvas");

      ctx=canvas.getContext("2d");

      //起始角度

      setInterval(function(){

      changeAngle();

      },500);

    }

    function changeAngle(){

      ctx.clearRect(0,0,400,400);

      startAngle==360?startAngle=0:startAngle++;

      draw(startAngle);

    }

    function draw(Angle) {

      for(var i=1;i<=number;i++) {

        var RGB = Math.floor(Math.random()*255);

        //遍历圆个数

        for(var j=1;j<=number2*i;j++) {

          var dx = canvas.width/2;//大圆圆心x坐标

          var dy = canvas.height/2;//大圆圆心y坐标

          //j*dig 所有圆跨的角度

          var dig = (Angle*2*Math.PI/360)+j*2*Math.PI/(number2*i);

          var R=(2*r+1)/2/(Math.sin(2*Math.PI/number2/2/i))

          var x=dx+Math.sin(Angle+dig)*R;

          var y=dy+Math.cos(Angle+dig)*R;

          ctx.beginPath();

          ctx.fillStyle ="rgb("+RGB+","+Math.floor(RGB/2)+","+(255-RGB)+")";

          ctx.arc(x,y,r,0,2*Math.PI,true);

          ctx.closePath();

          ctx.fill();

        }

      } 

    }

  </script>

</head>

<body align="center" onload="init()">

  <canvas id="canvas" width="400" height="400"></canvas>

</body>

</html>

相关文章

网友评论

      本文标题:利用canvas简单制作一个转动的圆

      本文链接:https://www.haomeiwen.com/subject/cqdbjttx.html