js實現(xiàn)可愛的氣泡特效
更新時間:2020年09月05日 10:08:30 作者:那誰呀撒
這篇文章主要為大家詳細介紹了js實現(xiàn)可愛的氣泡特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了js實現(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>
</head>
<body>
<canvas id="myCanvas"></canvas>
<script>
var c = document.getElementById("myCanvas");
c.width = 300;
c.height = 500;
var ctx = c.getContext('2d');
var arr = []
function sui() {
var r = Math.floor(Math.random() * 6 + 5);
var x = Math.floor(Math.random() * (c.width - 2 * r)) + r;
var y = c.height - r;
var opacity = Math.random();
var red = Math.floor(Math.random() * 256);
var green = Math.floor(Math.random() * 256);
var blue = Math.floor(Math.random() * 256);
var deg = 0;
var scale = Math.floor(Math.random() * 6 + 10);
arr.push({
x,
y,
r,
red,
green,
blue,
opacity,
deg,
scale
})
}
setInterval(sui, 40);
// 再實現(xiàn)變大和繪制
function dan() {
ctx.clearRect(0, 0, c.width, c.height);
arr.forEach((item, i) => {
item.deg += 0.5;
item.y -= item.deg;
item.x += Math.sin(item.deg) * item.scale;
if (item.y <= item.r) {
arr.splice(i, 1);
} else {
ctx.beginPath();
ctx.arc(item.x, item.y, item.r, 0, Math.PI * 2);
ctx.fillStyle = `rgba(${item.red},${item.green},${item.blue},${item.opacity})`;
ctx.fill();
}
})
}
setInterval(dan, 100);
</script>
</body>
</html>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
用JS提交參數(shù)創(chuàng)建form表單在FireFox中遇到的問題
在一個前端頁面上,需要通過JavaScript來提交參數(shù),使用JS創(chuàng)建form表單,將參數(shù)append到表單中進行提交,接下來將介紹如何操作與實現(xiàn)2013-01-01
詳解JavaScript中Hash Map映射結構的實現(xiàn)
Hash Map通常在JavaScript中作為一個簡單的來存儲鍵值對的地方,不過哈希對象Object并不是一個真正的哈希映射,沒Java中的Hash Map來的那么強大,well,接下來帶大家詳解JavaScript中Hash Map映射結構的實現(xiàn)2016-05-05
IntersectionObserver實現(xiàn)圖片懶加載的示例
下面小編就為大家?guī)硪黄狪ntersectionObserver實現(xiàn)圖片懶加載的示例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09

