基于html5绘制圆形多角图案
2016-04-21 09:23
645 查看
先看看最简单的效果图:
代码如下:
在上面多角形的基础上进一步之后为:
代码如下:
以上就是本文的全部内容,希望对大家的学习有所帮助。
代码如下:
var canvas = document.getElementById('my'), ctx = canvas.getContext('2d'); setInterval(function(){ ctx.clearRect(0,0,400,400); ctx.save(); ctx.translate(200,200); var ci =90, pi = Math.PI / ci, x1 = 100, y1 =0, x2 =0, y2 =0, x3 =0, y3 =0; ctx.beginPath(); for(var i = ci *2; i >0; i--){ ctx.rotate(pi); ctx.moveTo(x1,y1); y2 = x1 * Math.sin(pi); x2 = x1 * Math.cos(pi); x3 = (x1 - x2) /2+ x2 +10+ Math.random() *20; y3 = y2 /2; ctx.lineTo(x3,y3); ctx.lineTo(x2,y2); } ctx.stroke(); ctx.restore(); },100);
在上面多角形的基础上进一步之后为:
代码如下:
var canvas = document.getElementById('my'), ctx = canvas.getContext('2d'), r =10; setInterval(function(){ ctx.clearRect(0,0,400,400); ctx.save(); ctx.translate(200,200); var grad = ctx.createRadialGradient(0,0,0,0,0,r+20); grad.addColorStop(0.2,'white'); grad.addColorStop(0.7,'yellow'); grad.addColorStop(0.8,'orange'); ctx.beginPath(); ctx.fillStyle = grad; ctx.arc(0,0,r,0,Math.PI*2,true); ctx.fill(); var ci =90, pi = Math.PI / ci, x2 =0, y2 =0, x3 =0, y3 =0; x1 =100; y1 =0; ctx.beginPath(); for(var i = ci *2; i >0; i--){ ctx.rotate(pi); ctx.moveTo(r,0); y2 = r * Math.sin(pi); x2 = r * Math.cos(pi); x3 = (r - x2) /2+ x2 +10+ Math.random() *20; y3 = y2 /2; ctx.lineTo(x3,y3); ctx.lineTo(x2,y2); } ctx.fill(); ctx.restore(); r <=100&& (r +=2); },100);
以上就是本文的全部内容,希望对大家的学习有所帮助。
相关文章推荐
- HTML5中在客户端验证文件上传的大小
- html5 web数据存储
- 页面元素查找之Selectors API
- Canvas 在高清屏下绘制图片变模糊的解决方法
- 关于前端的思考与感悟
- 爆炸式的JS圆形浮动菜单特效代码
- 原生js结合html5制作小飞龙的简易跳球
- HTML5游戏引擎LTweenLite实现的超帅动画效果(附demo源码下载)
- 三个不常见的 HTML5 实用新特性简介
- 低版本IE正常运行HTML5+CSS3网站的3种解决方案
- js+HTML5实现canvas多种颜色渐变效果的方法
- javascript+HTML5的Canvas实现Lab单车动画效果
- javascript+html5实现绘制圆环的方法
- javascript html5实现表单验证
- HTML5实现微信拍摄上传照片功能
- JavaScript+html5 canvas制作的百花齐放效果完整实例
- jQuery+HTML5加入购物车代码分享
- jQuery mobile 移动web(6)
- 基于Jquery和html5的7款个性化地图插件