非常不错的canvas效果,线随心动

非常不错的canvas效果,下面是html代码。

  1 <!DOCTYPE html>
  2 <html>
  3  <head>
  4   <meta charset="utf-8" />
  5   <meta name="author" content="" />
  6   <meta name="keywords" content="" />
  7   <meta name="description" content="" />
  8   <meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no" />
  9   <title>  似圆非圆,似线非线 </title>
 10   <style>
 11     .stage{position:absolute;left:0;top:0;width:100%;height:100%;background:#000;}
 12   </style>
 13  </head>
 14  <body>
 15   <canvas class="stage"></canvas>
 16   <script>
 17     (function(win,el){
 18         var cvs=document.querySelector(el),
 19             ctx=cvs.getContext("2d"),
 20             width,
 21             height,
 22             mouse={},
 23             scale=1,
 24             min_scale=1,
 25             max_scale=2.5,
 26             isMouseDown=false,
 27             radius=50,
 28             circlesNum=10,
 29             circles=[];
 30 
 31             Function.prototype.method=function(k,v){
 32                return this.prototype[k]=v,this;
 33             };
 34 
 35             function Circle(x,y,center,radius){
 36                this.x=x;
 37                this.y=y;
 38                this.curX=x;
 39                this.curY=y;
 40                this.center=center;
 41                this.speed=0.01+Math.random()*0.04;
 42                this.angle=0;
 43                this.color="hsl("+Math.random()*360+",100%,50%)";
 44                this.lineWidth=1;
 45                this.targetWidth=5;
 46                this.radius=radius;
 47             }
 48 
 49             Circle.method("draw",function(ctx,zoom){
 50                 var x=this.x,y=this.y;
 51                 this.angle+=this.speed;
 52 
 53                 this.curX+=(this.center.x-this.curX)*this.speed;
 54                 this.curY+=(this.center.y-this.curY)*this.speed;
 55 
 56 
 57                 this.x=this.curX+Math.cos(this.angle)*this.radius*zoom;
 58                 this.y=this.curY+Math.sin(this.angle)*this.radius*zoom;
 59                 this.lineWidth+=(this.targetWidth-this.lineWidth)*0.05;
 60 
 61                 if(Math.abs(this.targetWidth-this.lineWidth)<0.5)
 62                 {
 63                    this.targetWidth=1+Math.random()*6;
 64                 }
 65 
 66                 ctx.strokeStyle=this.color;
 67                 ctx.lineWidth=this.lineWidth;
 68                 
 69                 
 70                 ctx.beginPath();
 71                 ctx.moveTo(x,y)
 72                 ctx.lineTo(this.x,this.y);
 73 
 74                 ctx.stroke();
 75     
 76             });
 77 
 78             function init(){
 79                 var bound=cvs.getBoundingClientRect(),i=circlesNum,segment=i*10;
 80                 cvs.width=width=bound.width;
 81                 cvs.height=height=bound.height;
 82 
 83                 ctx.fillStyle="rgba(0,0,0,.05)";
 84                 ctx.lineCap="round";
 85 
 86                 mouse.x=width/2;
 87                 mouse.y=height/2;
 88 
 89                 while(i--)
 90                   circles[i]=new Circle(0,0,mouse,radius+Math.random()*segment);
 91 
 92                 cvs.addEventListener("mousemove",function(e){
 93                     mouse.x=e.clientX;
 94                     mouse.y=e.clientY;
 95                 },false);
 96 
 97                 cvs.addEventListener("mousedown",function(){
 98                     isMouseDown=true;
 99                 },false);
100 
101                 cvs.addEventListener("mouseup",function(){
102                     isMouseDown=false;
103                 },false);
104                 cvs.addEventListener("mouseout",function(){
105                     isMouseDown=false;
106                 },false);
107 
108                 render();
109             }
110 
111             function render(){
112               var i=circlesNum;
113               scale+=isMouseDown?(max_scale-scale)*0.05:(min_scale-scale)*0.05;
114               ctx.fillRect(0,0,width,height);
115 
116               while(i--)
117                  circles[i].draw(ctx,scale);
118 
119               requestAnimationFrame(render);
120 
121             }
122 
123             init();
124 
125     })(this,".stage");
126   </script>
127  </body>
128 </html>

 

posted @ 2017-04-14 11:39  飘渺逸风  阅读(1226)  评论(0编辑  收藏  举报