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 相关文章推荐
js验证表单大全
Nov 25 Javascript
W3C Group的JavaScript1.8 新特性介绍
May 19 Javascript
去掉gridPanel表头全选框的小例子
Jul 18 Javascript
JavaScript实现广告的关闭与显示效果实例
Jul 02 Javascript
Bootstrap响应式侧边栏改进版
Sep 17 Javascript
vue数据双向绑定原理解析(get &amp; set)
Mar 08 Javascript
原生JS实现的雪花飘落动画效果
May 03 Javascript
Vue使用高德地图搭建实时公交应用功能(地图 + 附近站点+线路详情 + 输入提示+换乘详情)
May 16 Javascript
Node.js搭建WEB服务器的示例代码
Aug 15 Javascript
详解Axios统一错误处理与后置
Sep 26 Javascript
小程序采集录音并上传到后台
Nov 22 Javascript
Vue中Object.assign清空数据报错的解决方案
Mar 03 Vue.js
微信小程序 开发经验整理
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
ADODB类使用
2006/11/25 PHP
PHP5 安装方法
2007/01/15 PHP
laravel实现登录时监听事件,添加登录用户的记录方法
2019/09/30 PHP
JS实现可改变列宽的table实例
2013/07/02 Javascript
thinkjs 文件上传功能实例代码
2017/11/08 Javascript
微信小程序实现跟随菜单效果和循环嵌套加载数据
2017/11/21 Javascript
javaScript实现鼠标在文字上悬浮时弹出悬浮层效果
2020/04/12 Javascript
vue项目中实现的微信分享功能示例
2019/01/21 Javascript
JS中的算法与数据结构之链表(Linked-list)实例详解
2019/08/20 Javascript
简单了解JavaScript sort方法
2019/11/25 Javascript
JS写滑稽笑脸运动效果
2020/05/28 Javascript
OpenLayers3加载常用控件使用方法详解
2020/09/25 Javascript
多种类型jQuery网页验证码插件代码实例
2021/01/09 jQuery
python 运算符 供重载参考
2009/06/11 Python
Python selenium 三种等待方式详解(必会)
2016/09/15 Python
Python实现的简单模板引擎功能示例
2017/09/02 Python
Python实现求两个数组交集的方法示例
2019/02/23 Python
pyqt5 使用label控件实时显示时间的实例
2019/06/14 Python
Django结合ajax进行页面实时更新的例子
2019/08/12 Python
详解Python中打乱列表顺序random.shuffle()的使用方法
2019/11/11 Python
Python如何使用OS模块调用cmd
2020/02/27 Python
Python小整数对象池和字符串intern实例解析
2020/03/21 Python
Django 多对多字段的更新和插入数据实例
2020/03/31 Python
Python实现七个基本算法的实例代码
2020/10/08 Python
CSS3动画之流彩文字效果+图片模糊效果+边框伸展效果实现代码合集
2017/08/18 HTML / CSS
英国浴室洗脸盆购物网站:Click Basin
2018/06/08 全球购物
L*SPACE官网:比基尼、泳装和度假服装
2019/03/18 全球购物
技校生自我鉴定范文
2013/09/26 职场文书
实习生个人找工作的自我评价
2013/10/30 职场文书
自我鉴定写作要点
2014/01/17 职场文书
旅游管理专业大学生职业规划书
2014/02/27 职场文书
关于九一八事变的演讲稿2014
2014/09/17 职场文书
道德模范事迹材料
2014/12/20 职场文书
预备党员转正党小组意见
2015/06/01 职场文书
面试必问:圣杯布局和双飞翼布局的区别
2021/05/13 HTML / CSS
关于nginx 实现jira反向代理的问题
2021/09/25 Servers