canvas实现电闪雷鸣狂风暴雨的森林树木摇摆下雨动画效果代码
代码语言:html
所属分类:动画
代码描述:canvas实现电闪雷鸣狂风暴雨的森林树木摇摆下雨动画效果代码
代码标签: canvas 电闪雷鸣 狂风暴雨 森林 树木 摇摆 下雨 动画
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<style>
body {
margin: 0;
overflow: hidden;
background-color: #000;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
transition: background 0.1s ease-in-out;
}
canvas {
display: block;
}
button {
position: absolute;
top: 10px;
left: 10px;
z-index: 10;
padding: 10px;
background-color: #4caf50;
color: white;
border: none;
border-radius: 5px;
cursor: pointer;
font-size: 16px;
}
button:hover {
background-color: #45a049;
}
</style>
</head>
<body>
<canvas id="mainCanvas"></canvas>
<script>
const canvas = document.getElementById("mainCanvas");
const ctx = canvas.getContext("2d");
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
// Raindrop parameters
const maxRaindrops = 200;
let raindrops = [];
class Raindrop {
constructor(x, y, length, speed) {
this.x = x !== undefined ? x : Math.random() * canvas.width;
this.y = y !== undefined ? y : Math.random() * canvas.height;
this.length = length !== undefined ? length : Math.random() * 20 + 10;
this.speed = speed !== undefined ? speed : Math.random() * 10 + 5; // Increased speed
}
fall() {
this.y += this.speed;
if (this.y > canvas.height) {
this.y = 0 - this.length;
this.x = Math.random() * canvas.width;
this.speed = Math.random() * 10 + 5; // Increased speed
this.length = Math.random() * 20 + 10;
}
}
draw() {
ctx.beginPath();
ctx.moveTo(this.x, this.y);
ctx.lineTo(this.x, this.y + this.length);
ctx.strokeStyle = "blue";
ctx.lineWidth = 2;
ctx.stroke();
}}
// Lightning parameters
const numSegments = 10;
const segmentWidth = 10; // Smaller segment width for more vertical lines
const maxAmplitude = canvas.width / 6; // Control the horizontal amplitude
let offset = 0;
// Function to draw a single.........完整代码请登录后点击上方下载按钮下载查看
网友评论0