欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript+html5 canvas制作的百花齊放效果完整實(shí)例

 更新時(shí)間:2016年01月26日 12:00:00   作者:m1870164  
這篇文章主要介紹了JavaScript+html5 canvas制作的百花齊放效果,結(jié)合完整實(shí)例形式分析了使用html5的canvas技術(shù)動(dòng)態(tài)繪制圖形的技巧,需要的朋友可以參考下

本文實(shí)例講述了JavaScript+html5 canvas制作的百花齊放效果。分享給大家供大家參考,具體如下:

運(yùn)行效果截圖如下:

具體代碼如下:

<!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進(jìn)制隨機(jī)顏色值
   */
   dyl.getColor = function() {
    var color = "#";
    for(var i=0; i<6; i++) {
     color += dyl.colorList[Math.floor(Math.random()*dyl.colorListLength)];
    }
    return color;
   };
   /**
   * 一個(gè)隨機(jī)角度,隨機(jī)初始速度的斜拋對(duì)象
   */
   var Arc = function(i) {
    // 設(shè)置自有屬性
    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);
    }
   };
   /**
   * 初始化整個(gè)事件
   */
   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>

更多關(guān)于js特效相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery動(dòng)畫與特效用法總結(jié)》及《jQuery常見經(jīng)典特效匯總

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 利用JS進(jìn)行圖片的切換即特效展示圖片

    利用JS進(jìn)行圖片的切換即特效展示圖片

    做網(wǎng)頁時(shí)需要利用JS進(jìn)行特效展示圖片,下面是利用JS簡(jiǎn)單制作的圖片的切換,需要的朋友可以了解下
    2013-12-12
  • 在JavaScript中實(shí)現(xiàn)命名空間

    在JavaScript中實(shí)現(xiàn)命名空間

    在JavaScript中實(shí)現(xiàn)命名空間...
    2006-11-11
  • 如何基于原生javaScript生成帶圖片的二維碼

    如何基于原生javaScript生成帶圖片的二維碼

    這篇文章主要介紹了如何基于原生javaScript生成帶圖片的二維碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 分析ES5和ES6的apply區(qū)別

    分析ES5和ES6的apply區(qū)別

    這篇文章主要介紹了分析ES5和ES6的apply區(qū)別,對(duì)ES6感興趣的同學(xué),可以參考下
    2021-05-05
  • JavaScript字典與集合詳解

    JavaScript字典與集合詳解

    這篇文章主要介紹了JavaScript字典與集合詳解,集合是由一組無序且不重復(fù)的元素構(gòu)成。我們可以將集合看成一種特殊的數(shù)組,它的特殊之處就是無序且不重復(fù),這也就意味著我們不能通過下標(biāo)的方式進(jìn)行訪問,而且集合中不會(huì)出現(xiàn)重復(fù)的元素
    2022-07-07
  • 原生JS實(shí)現(xiàn)匯率轉(zhuǎn)換功能代碼實(shí)例

    原生JS實(shí)現(xiàn)匯率轉(zhuǎn)換功能代碼實(shí)例

    這篇文章主要介紹了原生JS實(shí)現(xiàn)匯率轉(zhuǎn)換功能代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • javascript中的隱式調(diào)用

    javascript中的隱式調(diào)用

    本篇文章給大家詳細(xì)介紹了javascript中的隱式調(diào)用相關(guān)知識(shí)點(diǎn),對(duì)此有興趣的可以跟著小編一起學(xué)習(xí)下。
    2018-02-02
  • 分享javascript計(jì)算時(shí)間差的示例代碼

    分享javascript計(jì)算時(shí)間差的示例代碼

    這篇文章主要為大家介紹了javascript計(jì)算時(shí)間差的示例代碼,,一般來說都是計(jì)算當(dāng)前時(shí)間和一個(gè)指定時(shí)間點(diǎn)之間的差距,感興趣的小伙伴們可以參考一下
    2016-01-01
  • javascript 組合按鍵事件監(jiān)聽實(shí)現(xiàn)代碼

    javascript 組合按鍵事件監(jiān)聽實(shí)現(xiàn)代碼

    這篇文章主要介紹了javascript 組合按鍵事件監(jiān)聽實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • js防止表單重復(fù)提交的兩種方法

    js防止表單重復(fù)提交的兩種方法

    第一種:用flag標(biāo)識(shí),下面的代碼設(shè)置checkSubmitFlg標(biāo)志;第二種:在onsubmit事件中設(shè)置,在第一次提交后使提交按鈕失效,感興趣的朋友可以了解下
    2013-09-09

最新評(píng)論