亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript canvas實(shí)現(xiàn)雨滴效果

瀏覽:5日期:2023-06-02 17:26:16

本文實(shí)例為大家分享了javascript canvas實(shí)現(xiàn)雨滴效果的具體代碼,供大家參考,具體內(nèi)容如下

先看效果

javascript canvas實(shí)現(xiàn)雨滴效果

看起來(lái)很炫酷,其實(shí)就是實(shí)現(xiàn)了雨滴的掉落還有最后的圓

還是看源碼

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title> <style>* { margin: 0; padding: 0;}body { background-color: #000;} </style></head><body> <canvas></canvas> <script>// 獲取畫布var canvas = document.querySelector(’canvas’)// 獲取畫筆var ctx = canvas.getContext(’2d’)// 不能用css改變畫布大小var ch = canvas.height = window.innerHeightvar cw = canvas.width = window.innerWidth// 放雨滴var arrRain = []// 監(jiān)聽屏幕大小,屏幕發(fā)生變化讓畫布也跟著改變大小window.onresize = function () { ch = canvas.height = window.innerHeight cw = canvas.width = window.innerWidth}// 獲取一個(gè)隨機(jī)數(shù),目的是為了生成隨機(jī)雨滴function randow(min, max) { return Math.random() * (max - min) + min}// 構(gòu)造函數(shù)function Rain() {}// 為rain添加屬性和方法Rain.prototype = { // 初始化位置和雨滴下落的圓的半徑 init: function () {this.x = randow(0, cw)this.y = 0// 雨滴最終落地的距離不能超出屏幕this.h = randow(0.8 * ch, 0.9 * ch)this.r = 1 // 開始圓的半徑this.vr = 1 // 半徑增長(zhǎng)的速度this.vy = randow(4, 5) }, // 畫方法 draw: function () {// 小于h的時(shí)候,畫雨滴,畫矩形if (this.y < this.h) { ctx.beginPath() ctx.fillStyle = ’white’ ctx.fillRect(this.x, this.y, 4, 10)} else { // 畫圓 ctx.beginPath() ctx.strokeStyle = ’white’ ctx.arc(this.x, this.y, this.r, 0, 2 * Math.PI) ctx.stroke()} }, // 雨滴移動(dòng) move: function () {// 小于h時(shí),加y實(shí)現(xiàn)雨滴移動(dòng)if (this.y < this.h) { this.y += this.vy} else { // 實(shí)現(xiàn)水花四濺的效果 if (this.r < 70) {this.r += this.vr } else {// 結(jié)束效果之后初始化,又從天上生成雨滴,所以要調(diào)用init函數(shù)this.init() }}this.draw() }}// 生成雨滴function createRain(num) { for (var i = 0; i < num; i++) {// 隨機(jī)生成雨滴,不是同時(shí)生成setTimeout(function () { var rain = new Rain() rain.init() rain.draw() arrRain.push(rain)}, 300 * i) }}createRain(60)setInterval(function () { ctx.beginPath() ctx.fillStyle = ’rgba(0,0,0,0.05)’ ctx.fillRect(0, 0, cw, ch) for (var k of arrRain) {k.move() }}, 1000 / 80) </script></body></html>

這些也就是雨滴實(shí)現(xiàn)的源碼,僅供參考。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 一级毛片完整免费版 | a级毛片免费看 | 亚洲一二三区久久五月天婷婷 | 国产a级特黄的片子视频免费 | 亚洲人成亚洲人成在线观看 | 成人黄色网 | 亚洲精品一区二区四季 | 91成人免费观看网站 | 美女国产精品福利视频 | 久久久久网站 | 欧美换爱交换乱理伦片不卡片 | 人九九精品 | 亚洲欧洲日产国码在线观看 | 又黄又爽一线毛片免费观看 | 天堂毛片 | 国产91精品高跟丝袜在线 | 国产一区二区久久 | 成年视频xxxxx免费播放软件 | 日本在线日本中文字幕日本在线视频播放 | 黄色网址大全免费 | 国产精品久久精品福利网站 | 国产免费播放 | 国产制服在线 | 成人免费淫片免费观看 | 国产三级电影院 | 我要看黄色录像一级片 | 爱操tv| 一级做a爱过程免费视频时看 | 国产一区二区视频在线播放 | 自拍偷拍1 | 香蕉成人啪国产精品视频综合网 | 第一区免费在线观看 | 久久久99精品久久久 | 毛片在线视频在线播放 | 亚洲一级片在线观看 | 久久99综合国产精品亚洲首页 | 精品国产免费人成在线观看 | 中文字幕日韩欧美一区二区三区 | 全黄a免费一级毛片人人爱 全黄一级裸片视频在线观看 | 欧美一级特黄aaaaaaa在线观看 | 国产黄a三级三级看三级 |