canvas绘制万花筒效果(代码分享)
2017-01-20 15:12
761 查看
话不多说,请看代码:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>万花筒</title> <style> canvas{ background:#eee; } </style> <script> window.onload = function(){ var canvas = document.getElementById("canvas"); var cobj = canvas.getContext("2d"); var arr = []; var t=setInterval(function(){ cobj.clearRect(0,0,600,600); for(var i=0;i<arr.length;i++){ cobj.save(); cobj.translate(300,300); cobj.scale(arr[i].scales,arr[i].scales); cobj.rotate(arr[i].angle*Math.PI/180); cobj.fillStyle = arr[i].color; cobj.fillRect(arr[i].num,arr[i].num,30,30); cobj.restore(); } },50); setInterval(function(){ for(var i=0;i<arr.length;i++){ if(arr[i].num<=0){ arr.splice(i,1); continue; } arr[i].angle+=2; arr[i].num-=0.2; arr[i].scales-=0.002; if(arr[i].scales<=0.2){ arr[i].scales=0.2; } } },50); setInterval(function(){ var rect = {angle:0,num:150,scales:1,color:"rgb("+parseInt(Math.random()*255)+","+parseInt(Math.random()*255)+","+parseInt(Math.random()*255)+")"}; arr.push(rect); },600); } </script> </head> <body> <canvas width="600" height="600" id="canvas"></canvas> </body> </html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!
您可能感兴趣的文章:
相关文章推荐
- canvas雪花效果核心代码分享
- Android 拖拽效果实现代码分享 - ORIETech
- 3D切换界面效果代码分享
- HTML5 Canvas 绘制齿轮【每日一段代码34】
- 分享一个超酷的开源html5 canvas互动网络图形效果javascript类库 - sigma.js
- 分享一个超酷的开源html5 canvas互动网络图形效果javascript类库 - sig...
- IE 下VML动画的奇怪现象:GWTCanvas基于定时器的图形动画当鼠标移动时停止动画效果(直接用VML写代码效果也一样)
- 分享一段C#使用指针的代码!! 马赛克效果
- HTML5 Canvas 绘制螺旋线【每日一段代码30】
- Html5 Canvas绘制锯齿形【每日一段代码29】
- 分享一个自已写的仿iphone手机滑动效果的JS代码....
- 纯css的accordion效果(代码分享)
- Canvas绘制矩形的三个函数【每日一段代码7】
- Canvas绘制重叠矩形【每日一段代码6】
- HTML5 Canvas 绘制二次曲线【每日一段代码31】
- 网页滚动效果代码分享
- Canvas绘制三角形路径【每日一段代码9】
- HTML5 Canvas 绘制树 【每日一段代码38】
- canvas绘制的小效果