色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

原生js+canvas實現下雪效果

瀏覽:114日期:2024-04-27 09:55:01

本文實例為大家分享了js+canvas實現下雪效果的具體代碼,供大家參考,具體內容如下

效果展示:

原生js+canvas實現下雪效果

源碼展示:

<!doctype html><html><head> <meta charset='utf-8'> <title>canvas下雪效果(原生js)</title> <style> * { margin: 0; padding: 0 } html, body { width: 100%; height: 100%; overflow: hidden; background-color: #222; } #canvas { position: absolute; top: 0; left: 0; } </style></head><body><canvas id='canvas'></canvas><img src='http://m.lshqa.cn/bcjs/xh.png' alt='雪花'><img src='http://m.lshqa.cn/bcjs/bj.jpg' alt='背景'> <script> window.onload = function () { var canvas = document.getElementById('canvas'); var imgSnow = document.getElementById('imgSnow'); var bgSnow = document.getElementById('bgSnow'); var ctx = canvas.getContext(’2d’); var mbody = document.querySelector('body'); canvas.width =mbody.offsetWidth; canvas.height = mbody.offsetHeight; var GetRandomNum = function (Min, Max) { var Range = Max - Min; var Rand = Math.random(); return (Min + Math.round(Rand * Range)); } // console.log(GetRandomNum(0, canvas.width)) var snowArray = {}; //雪花對象 var snowIndex = 0; //標識符 var setting = { num: 30, //數量 snowSize: 20, //大小 startX: Math.random() * canvas.width, //起始橫坐標 startY: 0, //起始縱坐標 vy: 0.01 } function snow() { // 起始橫坐標 this.x = Math.random() * canvas.width; // 起始縱坐標 this.y = setting.startY; this.size = setting.snowSize + Math.random() * 10 - 10; //橫坐標偏移量 this.vx = Math.random() * 3 - 2; //偏移量 //縱坐標偏移量 this.vy = Math.random() * 10; this.life = 0; this.maxLife = 100; this.id = snowIndex; //當前信息保存至對象snowArray snowArray[snowIndex] = this; snowIndex++; } snow.prototype.draw = function () { this.x += this.vx; this.y += this.vy; this.vy += setting.vy; this.life++; //刪除 if (this.y > canvas.height * 0.9 - 20) { snowArray[this.id] } else if (this.life >= this.maxLife) { snowArray[this.id] } ctx.drawImage(imgSnow, this.x, this.y, this.size, this.size) } setInterval(function () { ctx.drawImage(bgSnow, 0, 0, canvas.width, canvas.height); //數 for (var i = 0; i < setting.num; i++) { if (Math.random() > 0.97) { new snow(); } } for (var i in snowArray) { snowArray[i].draw(); } }, 100)202082104246954 }</script> </body></html>

圖片:

原生js+canvas實現下雪效果

雪花:

原生js+canvas實現下雪效果

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲欧美综合国产精品一区 | 国产亚洲精品2021自在线 | 成人a毛片免费全部播放 | 综合欧美一区二区三区 | 亚洲国产精品热久久2022 | 亚洲欧美日韩精品久久亚洲区色播 | 怡红院成人在线 | 精品在线观看一区 | 国产日本三级欧美三级妇三级四 | 国产国语高清在线视频二区 | 欧美成人看片一区二区三区尤物 | 91亚洲自偷手机在线观看 | 久久久久琪琪去精品色村长 | 一级做性色a爰片久久毛片免费 | 免费久久久久 | 鲁大师成人精品视频 | 伊人久热这里只有精品视频99 | 亚洲免费看片 | 久久精品道一区二区三区 | 亚洲欧美激情视频 | 国产伦精品一区二区三区四区 | 久久精品国产精品亚洲精品 | 国产精品99久久久久久宅男 | 久草最新在线 | 国产精品亚洲精品爽爽 | 久久久久久久久一次 | 高清欧美日本视频免费观看 | 国产一级视频在线 | 一级一级一片在线观看 | 手机毛片在线观看 | 成人公开免费视频 | 91久久精品国产91久久性色tv | 91精品国产91久久久久久 | 日本久久久久久久 | 久久久久久久久久久福利观看 | 一级a毛片免费观看 | 在线国产高清 | 国产精品久久自在自线观看 | 成 人 在 线 免费 8888 www | 国产高清免费观看 | 天堂8资源在线官网资源 |