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 学习笔记(四)
Dec 31 Javascript
js判断上传文件类型判断FileUpload文件类型代码
May 20 Javascript
js控制网页前进和后退的方法
Jun 08 Javascript
使用PBFunc在Powerbuilder中支付宝当面付款功能
Oct 01 Javascript
利用Vue.js实现checkbox的全选反选效果
Jan 18 Javascript
浅谈Angular2 ng-content 指令在组件中嵌入内容
Aug 18 Javascript
浅析Visual Studio Code断点调试Vue
Feb 27 Javascript
JS实现的检验身份证格式并输出出生日期,年龄,性别,出生地示例
May 17 Javascript
Vue实现表格批量审核功能实例代码
May 28 Javascript
node.js文件操作系统实例详解
Nov 05 Javascript
vue-cli3访问public文件夹静态资源报错的解决方式
Sep 02 Javascript
JS新手入门数组处理的实用方法汇总
Apr 07 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与Java进行通信的实现方法
2013/10/21 PHP
Yii2.0 RESTful API 基础配置教程详解
2018/12/26 PHP
php 函数中静态变量使用的问题实例分析
2020/03/05 PHP
使用jscript实现二进制读写脚本代码
2008/06/09 Javascript
Js动态创建div
2008/09/25 Javascript
JS正则表达式获取分组内容的方法详解
2013/11/15 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
javascript实现textarea中tab键的缩排处理方法
2015/06/26 Javascript
jQuery入门基础知识学习指南
2015/08/14 Javascript
js实现的星星评分功能函数
2015/12/09 Javascript
Javascript中神奇的this
2016/01/20 Javascript
javascript每日必学之运算符
2016/02/16 Javascript
JavaScript 消息框效果【实现代码】
2016/04/27 Javascript
JS实现隐藏同级元素后只显示JS文件内容的方法
2016/09/04 Javascript
Bootstrap CSS布局之代码
2016/12/17 Javascript
浅谈键盘上回车按钮的js触发事件
2017/02/13 Javascript
AngularJS表格样式简单设置方法示例
2017/03/03 Javascript
JavaScript类的继承多种实现方法
2020/05/30 Javascript
JavaScript中的执行环境和作用域链
2020/09/04 Javascript
node.js 基于 STMP 协议和 EWS 协议发送邮件
2021/02/14 Javascript
[48:24]完美世界DOTA2联赛PWL S3 Forest vs INK ICE 第一场 12.09
2020/12/12 DOTA
python中类变量与成员变量的使用注意点总结
2017/04/29 Python
Python基于回溯法子集树模板实现图的遍历功能示例
2017/09/05 Python
Python编程flask使用页面模版的方法
2018/12/28 Python
Python使用Beautiful Soup爬取豆瓣音乐排行榜过程解析
2019/08/15 Python
Python +Selenium解决图片验证码登录或注册问题(推荐)
2020/02/09 Python
python3中for循环踩过的坑记录
2020/12/14 Python
css3 图片圆形显示 如何CSS将正方形图片显示为圆形图片布局
2014/10/10 HTML / CSS
奥地利网上书店:Weltbild
2017/07/14 全球购物
管理科学大学生求职信
2013/11/13 职场文书
工业学校毕业生自荐书
2014/01/03 职场文书
工作表扬信的范文
2014/01/10 职场文书
工程资料员岗位职责
2014/03/10 职场文书
党建目标管理责任书
2014/07/25 职场文书
撤诉书怎么写
2015/05/19 职场文书
高三数学教学反思
2016/02/18 职场文书