怎样用JavaScript实现简单的雨滴效果?
Admin 2021-09-11 群英技术资讯 666 次浏览
今天给大家分享的是关于javascript实现雨滴效果的内容,实现效果如下,有雨滴掉落及最后变成圆的效果,那么这是怎样做的呢?下文有实例供大家参考,接下来跟随小编一起看看吧。
先看效果
看起来很炫酷,其实就是实现了雨滴的掉落还有最后的圆
还是看源码
<!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.innerHeight var cw = canvas.width = window.innerWidth // 放雨滴 var arrRain = [] // 监听屏幕大小,屏幕发生变化让画布也跟着改变大小 window.onresize = function () { ch = canvas.height = window.innerHeight cw = canvas.width = window.innerWidth } // 获取一个随机数,目的是为了生成随机雨滴 function randow(min, max) { return Math.random() * (max - min) + min } // 构造函数 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 // 半径增长的速度 this.vy = randow(4, 5) }, // 画方法 draw: function () { // 小于h的时候,画雨滴,画矩形 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() } }, // 雨滴移动 move: function () { // 小于h时,加y实现雨滴移动 if (this.y < this.h) { this.y += this.vy } else { // 实现水花四溅的效果 if (this.r < 70) { this.r += this.vr } else { // 结束效果之后初始化,又从天上生成雨滴,所以要调用init函数 this.init() } } this.draw() } } // 生成雨滴 function createRain(num) { for (var i = 0; i < num; i++) { // 随机生成雨滴,不是同时生成 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>
关于javascript实现雨滴效果就介绍到这,上述代码仅供参考,感兴趣的朋友可以看看,希望能对大家有帮助,想要了解更多JavaScript的内容,大家可以关注群英网络其它相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了VUE+Canvas实现财神爷接元宝小游戏,需要的朋友可以参考下本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
vue3 沙箱主要分两种,浏览器编译版本,浏览器版本是使用with语法加上proxy代理拦截;本地预编译版本,通过在模版预编译阶段转换阶段,使用转换插件transformExpression将非白名单标识符挂在在组件代理对象下
这篇文章主要介绍了vue多页面配置,单页应用这个概念,是随着前几年 AngularJS、React、Ember 等这些框架的出现而出现的。在前面的前言内容里,我们在页面渲染中讲了页面的局部刷新,而单页应用则是使用了页面的局部刷新的能力,下面来看看详细内容,需要的朋友可以参考一下
使用JavaScript获取扫码枪扫描得到的条形码的思路代码详解,下面通过实例代码给大家介绍js扫码枪扫描条形码的实现方法,具体代码如下所示:
就像其他人一样,开发人员喜欢知道一些可以展示给同事或朋友的小技巧。今天,我决定写一些键盘魔术,你可以在使用 Node Package Manager(NPM) 时使用它们。这些不仅会给你和你周围的人留下深刻的印象,而且也会让你...
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008