Canvas实现放射线动画效果


Posted in Javascript onFebruary 15, 2017

效果如下:

Canvas实现放射线动画效果

代码如下:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <style>
 body {background: #000;overflow: hidden;margin: 0;padding: 0;}
 #canv {width: 45%;margin: 5% 30%;animation: wheel-rotate 30s linear infinite;}
 @keyframes wheel-rotate {
 from {
 transform: rotate(0deg);
 }
 to {
 transform: rotate(360deg);
 }
 }
 </style>
 </head>
 <body>
 <canvas id="canv" width="600" height="600"></canvas>
 <script type="text/javascript">
 var c;
 var $;
 var w = 600;
 var h = 600;
 constant = 15;
 var rad = 300;
 var timeout = 0;
 c = document.getElementById("canv");
 $ = c.getContext("2d");
 drawLines();
 function drawLines() {
 $.fillRect(0,0,w,h);
 $.translate(w/2,h/2);
 for (var i = 0; i < 25; i++) {
 for (var n = -45; n <= 45; n+=constant) {
 setTimeout("draw("+n+");",100 * timeout);
 timeout++;
 }
 }
 }
 function draw(n){
 $.beginPath();
 $.moveTo(0,rad);
 var radians = Math.PI/180*n;
 var x = (rad * Math.sin(radians)) / Math.sin(Math.PI/2 - radians);
 $.lineTo(x,0);
 if (Math.abs(n) == 45) {
 $.strokeStyle=rndColor();
 $.lineWidth=2;
 } else if (n == 0) {
 $.strokeStyle="rgb(200,200,200)";
 $.lineWidth=.5;
 } else {
 $.strokeStyle="rgb(110,110,110)";
 $.lineWidth=.5;
 }
 $.stroke();
 $.rotate((Math.PI/180)*15);
 }
 function rndColor() {
 var r = 255*Math.random()|0,
  g = 255*Math.random()|0,
  b = 255*Math.random()|0;
 return 'rgb(' + r + ',' + g + ',' + b + ')';
 }
 function myrefresh(){
  //window.location.reload();
  //drawLines()
 }
 //setTimeout('myrefresh()',100*175);
 </script>
 </body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript iframe内的函数调用实现方法
Jul 19 Javascript
js取float型小数点后两位数的方法
Jan 18 Javascript
深入理解JavaScript系列(30):设计模式之外观模式详解
Mar 03 Javascript
jquery实现动态改变div宽度和高度
May 08 Javascript
jQuery动画效果图片轮播特效
Jan 12 Javascript
AngularJS中isolate scope的用法分析
Nov 22 Javascript
JS组件系列之JS组件封装过程详解
Apr 28 Javascript
requirejs按需加载angularjs文件实例
Jun 08 Javascript
JavaScript用二分法查找数据的实例代码
Jun 17 Javascript
Vue+ElementUI table实现表格分页
Dec 14 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
Mar 10 Javascript
JavaScript装箱及拆箱boxing及unBoxing用法解析
Jun 15 Javascript
微信小程序 开发经验整理
Feb 15 #Javascript
bootstrap table操作技巧分享
Feb 15 #Javascript
利用n 升级工具升级Node.js版本及在mac环境下的坑
Feb 15 #Javascript
JS原型与原型链的深入理解
Feb 15 #Javascript
js中数组插入、删除元素操作的方法
Feb 15 #Javascript
jQuery中on方法使用注意事项详解
Feb 15 #Javascript
防止重复发送 Ajax 请求
Feb 15 #Javascript
You might like
通过chrome浏览器控制台(Console)进行PHP Debug的方法
2016/10/19 PHP
prototype Element学习笔记(篇一)
2008/10/26 Javascript
jquery blockUI 遮罩不能消失与不能提交的解决方法
2011/09/17 Javascript
setTimeout和setInterval的深入理解
2013/11/08 Javascript
优化Jquery,提升网页加载速度
2013/11/14 Javascript
JavaScript中for循环的使用详解
2015/06/03 Javascript
jQuery替换textarea中换行的方法
2015/06/10 Javascript
Angularjs中的事件广播 —全面解析$broadcast,$emit,$on
2016/05/17 Javascript
用headjs来管理和加载js 提高网站加载速度
2016/11/29 Javascript
JS实现简单的二元方程计算器功能示例
2017/01/03 Javascript
jQuery的中 is(':visible') 解析及用法(必看)
2017/02/12 Javascript
jQuery实现返回顶部按钮和scroll滚动功能[带动画效果]
2017/07/05 jQuery
vue中v-model的应用及使用详解
2018/06/27 Javascript
vscode下的vue文件格式化问题
2018/11/28 Javascript
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
2019/05/13 Javascript
react使用CSS实现react动画功能示例
2020/05/18 Javascript
Vue与React的区别和优势对比
2020/12/18 Vue.js
JS+JQuery实现无缝连接轮播图
2020/12/30 jQuery
前端如何实现动画过渡效果
2021/02/05 Javascript
给Python初学者的一些编程技巧
2015/04/03 Python
Python3学习urllib的使用方法示例
2017/11/29 Python
python做量化投资系列之比特币初始配置
2018/01/23 Python
Win7 64位下python3.6.5安装配置图文教程
2020/10/27 Python
python opencv 实现对图像边缘扩充
2020/01/19 Python
使用python采集Excel表中某一格数据
2020/05/14 Python
详解python中的lambda与sorted函数
2020/09/04 Python
英国领先品牌手动工具和电动工具供应商:Tooled Up
2018/11/24 全球购物
JAVA招聘远程笔试题
2015/07/23 面试题
工作失误检讨书范文大全
2014/01/13 职场文书
高中英语教学反思
2014/02/04 职场文书
运动会口号16字
2014/06/07 职场文书
运动会稿件100字
2014/09/24 职场文书
2014年公务员转正工作总结
2014/11/07 职场文书
2014年政务公开工作总结
2014/12/09 职场文书
2015年考研复习计划
2015/01/19 职场文书
python中sys模块的介绍与实例
2021/04/17 Python