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 相关文章推荐
读jQuery之四(优雅的迭代)
Jun 20 Javascript
加载 Javascript 最佳实践
Oct 30 Javascript
面向对象的Javascript之三(封装和信息隐藏)
Jan 27 Javascript
jQuery中的$.ajax()方法应用
May 06 Javascript
浅谈JavaScript Date日期和时间对象
Dec 29 Javascript
jQuery左侧大图右侧小图焦点图幻灯切换代码分享
Aug 19 Javascript
基于jquery实现鼠标滚轮驱动的图片切换效果
Oct 26 Javascript
基于jQuery实现左侧菜单栏可折叠功能
Dec 27 Javascript
JS区分Object与Aarry的六种方法总结
Feb 27 Javascript
浅谈struts1 &amp; jquery form 文件异步上传
May 25 jQuery
微信小程序pinker组件使用实现自动相减日期
May 07 Javascript
Vue实现点击导航栏当前标签后变色功能
Aug 19 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
php类常量的使用详解
2013/06/08 PHP
php实现压缩多个CSS与JS文件的方法
2014/11/11 PHP
对采用动态原型方式无法展示继承机制得思考
2009/12/04 Javascript
用js实现层随着内容大小动态渐变改变 推荐
2009/12/19 Javascript
Google排名中的10个最著名的 JavaScript库
2010/04/27 Javascript
Jquery事件的连接使用示例
2013/06/18 Javascript
jQuery中使用data()方法读取HTML5自定义属性data-*实例
2014/04/11 Javascript
js获取指定日期周数以及星期几的小例子
2014/06/27 Javascript
jQuery中height()方法用法实例
2014/12/24 Javascript
javascript实现加载xml文件的方法
2015/11/24 Javascript
微信小程序 设置启动页面的两种方法
2017/03/09 Javascript
深入探究angular2 UI组件之primeNG用法
2017/07/26 Javascript
jquery 一键复制到剪切板的实例
2017/09/20 jQuery
Vue 通过自定义指令回顾v-内置指令(小结)
2018/09/03 Javascript
详解Angular6学习笔记之主从组件
2018/09/05 Javascript
ng-repeat指令在迭代对象时的去重方法
2018/10/02 Javascript
谈谈为什么你的 JavaScript 代码如此冗长
2019/01/30 Javascript
如何让Nodejs支持H5 History模式(connect-history-api-fallback源码分析)
2019/05/30 NodeJs
[40:57]TI4 循环赛第二日 iG vs EG
2014/07/11 DOTA
使用python 获取进程pid号的方法
2014/03/10 Python
Python中for循环和while循环的基本使用方法
2015/08/21 Python
简单实现python爬虫功能
2015/12/31 Python
Python类的动态修改的实例方法
2017/03/24 Python
Python cookbook(数据结构与算法)实现查找两个字典相同点的方法
2018/02/18 Python
Python实现合并两个有序链表的方法示例
2019/01/31 Python
python和pywin32实现窗口查找、遍历和点击的示例代码
2020/04/01 Python
windows python3安装Jupyter Notebooks教程
2020/04/13 Python
介绍一下Ruby的特点
2013/01/20 面试题
控制工程专业个人求职信
2013/09/25 职场文书
个人查摆剖析材料
2014/02/04 职场文书
六年级学生评语
2014/04/22 职场文书
应聘教师求职信
2014/07/19 职场文书
刑事辩护授权委托书范本
2014/10/17 职场文书
开业庆典嘉宾致辞
2015/08/01 职场文书
Pytorch 使用tensor特定条件判断索引
2021/04/08 Python
Vue组件更新数据v-model不生效的解决
2022/04/02 Vue.js