JavaScript+html5 canvas制作的百花齐放效果完整实例


Posted in Javascript onJanuary 26, 2016

本文实例讲述了JavaScript+html5 canvas制作的百花齐放效果。分享给大家供大家参考,具体如下:

运行效果截图如下:

JavaScript+html5 canvas制作的百花齐放效果完整实例

具体代码如下:

<!DOCTYPE html>
<html>
 <head>
  <title>demo</title>
  <style type="text/css">
   body {
    margin:0; padding:0; 
   }
   #canvas {
    border:5px solid gray; box-shadow:0 0 15px 15px #494949 inset;
    margin-top:50px; margin-left:200px;
   }
  </style>
 </head>
 <body >
  <canvas id="canvas" width="1000px" height="500px"></canvas>
  <script type="text/javascript">
   var dyl = {};
   dyl.canvas = document.getElementById("canvas");
   dyl.ctx = dyl.canvas.getContext("2d");
   dyl.runTime = 0;
   dyl.colorList = "01234567890ABCDEFabcdef".split("");
   dyl.colorListLength = dyl.colorList.length;
   dyl.arcList = null;
   /**
   * 得到16进制随机颜色值
   */
   dyl.getColor = function() {
    var color = "#";
    for(var i=0; i<6; i++) {
     color += dyl.colorList[Math.floor(Math.random()*dyl.colorListLength)];
    }
    return color;
   };
   /**
   * 一个随机角度,随机初始速度的斜抛对象
   */
   var Arc = function(i) {
    // 设置自有属性
    this.v = Math.round(Math.random()*100)+50;
    this.angle = Math.round(Math.random()*145) + 45;
    this.startTime = +new Date();
    this._angle = this.angle/180*Math.PI;
    this.v_x = this.v*Math.cos(this._angle);
    this.v_y_start = this.v*Math.sin(this._angle);
    this.color = dyl.getColor();
    this.x = 500;
    this.g = 250;
    this.y = 490;
    this.index = i;
    var _self = this;
    this.run = function() {
     var endTime = +new Date();
     var timeSpan = (endTime - _self.startTime)/1000;
     var v_y_now = _self.v_y_start - 1/2*_self.g*Math.pow(timeSpan, 2);
     _self.x = _self.x +_self.v_x * timeSpan;
     _self.y = _self.y - (_self.v_y_start * timeSpan - 1/2*_self.g*Math.pow(timeSpan, 2));
     return this;
    };
    return this;
   };
   /**
   * 全局绘制图像
   */
   dyl.draw = function() {
    var arcList = dyl.arcList;
    var ctx = dyl.ctx;
    dyl.runTime++;
    for(var i=0, length=arcList.length; i<length; i++) {
     var arc = arcList[i];
     if(!arc) {
      continue;
     }
     arc.run();
     ctx.save();
     ctx.beginPath();
     ctx.fillStyle = arc.color;
     ctx.arc(arc.x, arc.y, 2, 0, Math.PI*2);
     ctx.fill();
     ctx.closePath();
     ctx.restore();
    }
    console.log(dyl.runTime);
    if(dyl.runTime >= 25) {
     setTimeout(dyl.init, 1050);
    } else {
     setTimeout(dyl.draw, 20);
    }
   };
   /**
   * 初始化整个事件
   */
   dyl.init = function() {
    dyl.ctx.clearRect(0, 0, 1000, 500);
    dyl.arcList = [];
    dyl.runTime = 0;
    for(var i=0; i<100; i++) {
     dyl.arcList.push(new Arc(i));
    }
    dyl.draw();
   };
   dyl.init();
  </script>
 </body>
</html>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript游戏之优化篇
Nov 08 Javascript
jQuery 开发者应该注意的9个错误
May 03 Javascript
javascript中闭包(Closure)详解
Jan 06 Javascript
jQuery插件ajaxfileupload.js实现上传文件
Oct 23 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
May 09 Javascript
jQuery设置聚焦并使光标位置在文字最后的实现方法
Aug 02 Javascript
javascript代码调试之console.log 用法图文详解
Sep 30 Javascript
AngularJS实现用户登录状态判断的方法(Model添加拦截过滤器,路由增加限制)
Dec 12 Javascript
浅析bootstrap原理及优缺点
Mar 19 Javascript
vue2.0移除或更改的一些东西(移除index key)
Aug 28 Javascript
angularjs路由传值$routeParams详解
Sep 05 Javascript
JS实现骰子3D旋转效果
Oct 24 Javascript
JavaScript+html5 canvas绘制渐变区域完整实例
Jan 26 #Javascript
Javascript中匿名函数的调用与写法实例详解(多种)
Jan 26 #Javascript
JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
Jan 26 #Javascript
JS组件Bootstrap Select2使用方法详解
Apr 17 #Javascript
基于JavaScript实现全屏透明遮罩div层锁屏效果
Jan 26 #Javascript
Hallo.js基于jQuery UI所见即所得的Web编辑器
Jan 26 #Javascript
基于JavaScript如何制作遮罩层对话框
Jan 26 #Javascript
You might like
分享下页面关键字抓取components.arrow.com站点代码
2014/01/30 PHP
php目录遍历函数opendir用法实例
2014/11/20 PHP
PHP实现网页内容html标签补全和过滤的方法小结【2种方法】
2017/04/27 PHP
PHP安装memcache扩展的步骤讲解
2019/02/14 PHP
为你的 Laravel 验证器加上多验证场景的实现
2020/04/07 PHP
javascript innerHTML、outerHTML、innerText、outerText的区别
2008/11/24 Javascript
javascript中的变量是传值还是传址的?
2010/04/19 Javascript
JavaScript类和继承 this属性使用说明
2010/09/03 Javascript
ajax更新数据后,jquery、jq失效问题
2011/03/16 Javascript
JQuery实现带排序功能的权限选择实例
2015/05/18 Javascript
理解javascript闭包
2015/12/15 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
移动开发之自适应手机屏幕宽度
2016/11/23 Javascript
js实现开启密码大写提示
2016/12/21 Javascript
微信小程序 MD5加密登录密码详解及实例代码
2017/01/12 Javascript
js实现横向拖拽导航条功能
2017/02/17 Javascript
详解Angularjs 自定义指令中的数据绑定
2018/07/19 Javascript
vue用BMap百度地图实现即时搜索功能
2019/09/26 Javascript
JavaScript实现放大镜效果代码示例
2020/04/29 Javascript
Python中的引用和拷贝浅析
2014/11/22 Python
Python数据结构与算法之图的广度优先与深度优先搜索算法示例
2017/12/14 Python
python实现事件驱动
2018/11/21 Python
tensorflow指定GPU与动态分配GPU memory设置
2020/02/03 Python
基于python实现ROC曲线绘制广场解析
2020/06/28 Python
使用Python实现NBA球员数据查询小程序功能
2020/11/09 Python
HTML5新增元素如何兼容旧浏览器有哪些方法
2014/05/09 HTML / CSS
2014年两会学习心得体会
2014/03/10 职场文书
辅导员评语
2014/05/04 职场文书
化学专业大学生职业生涯规划范文
2014/09/13 职场文书
2014幼儿园中班工作总结
2014/11/10 职场文书
2014年安置帮教工作总结
2014/12/11 职场文书
2015年综治维稳工作总结
2015/04/07 职场文书
乡镇司法所2015年度工作总结
2015/10/14 职场文书
公务员岗前培训心得体会
2016/01/08 职场文书
用Python的绘图库(matplotlib)绘制小波能量谱
2021/04/17 Python
微信小程序APP页面的之间的相互传递参数以及自定义组件
2022/04/19 Javascript