第一次:HTML 背景下雪特效
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
}
canvas {
display: block;
}
</style>
<title>Snow Effect</title>
</head>
<body>
<canvas id="snow"></canvas>
<script>
const canvas = document.getElementById('snow');
const ctx = canvas.getContext('2d');
let width = canvas.width = window.innerWidth;
let height = canvas.height = window.innerHeight;
const snowflakes = [];
function createSnowflakes() {
for (let i = 0; i < 300; i++) {
snowflakes.push({
x: Math.random() * width,
y: Math.random() * height,
radius: Math.random() * 4 + 1,
density: Math.random() * 10
});
}
}
function drawSnowflakes() {
ctx.clearRect(0, 0, width, height);
ctx.fillStyle = '#fff';
ctx.beginPath();
for (let i = 0; i < 300; i++) {
const snowflake = snowflakes[i];
ctx.moveTo(snowflake.x, snowflake.y);
ctx.arc(snowflake.x, snowflake.y, snowflake.radius, 0, Math.PI * 2, true);
}
ctx.fill();
updateSnowflakes();
}
let angle = 0;
function updateSnowflakes() {
for (let i = 0; i < 300; i++) {
const snowflake = snowflakes[i];
snowflake.y += Math.cos(angle) + snowflake.density + snowflake.radius / 2;
snowflake.x += Math.sin(angle) * 2;
if (snowflake.x > width || snowflake.x < 0 || snowflake.y > height) {
if (i % 3 > 0) {
snowflakes[i] = { x: Math.random() * width, y: -10, radius: snowflake.radius, density: snowflake.density };
} else {
if (Math.sin(angle) > 0) {
snowflakes[i] = { x: -5, y: Math.random() * height, radius: snowflake.radius, density: snowflake.density };
} else {
snowflakes[i] = { x: width + 5, y: Math.random() * height, radius: snowflake.radius, density: snowflake.density };
}
}
}
}
}
function startSnowfall() {
createSnowflakes();
requestAnimationFrame(drawSnowflakes);
}
startSnowfall();
window.addEventListener('resize', function() {
width = canvas.width = window.innerWidth;
height = canvas.height = window.innerHeight;
});
</script>
</body>
</html>
这段代码使用 HTML5 的 canvas 元素以及 JavaScript 来创建了一个简单的下雪特效。每个雪花都是一个随机位置的圆形,并且通过不断地更新它们的位置来模拟下雪效果。可以将这段代码添加到你的 HTML 文件中并查看效果。
结果
屏幕一篇白茫茫。啥都没有啊。我以为雪花是白色的,然后把屏幕调成了黑色,然后就是黑漆漆一篇,啥都没有。
第二次:HTML 背景下雪动画特效
代码
你可以使用 HTML、CSS 和 JavaScript 来创建一个简单的背景下雪动画特效。以下是一个示例代码:
HTML:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="styles.css">
<title>Snow Animation</title>
</head>
<body>
<div class="snowflakes"></div>
<script src="scripts.js"></script>
</body>
</html>
CSS (styles.css):
body, html {
margin: 0;
padding: 0;
width: 100%;
height: 100%;
overflow: hidden;
background-color: #000;
}
.snowflakes {
position: absolute;
width: 100%;
height: 100%;
background: url('snowflake.png') repeat top center;
z-index: 1;
pointer-events: none;
animation: snow 10s linear infinite; /* 控制下雪速度 */
}
@keyframes snow {
0% {
background-position: 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px, 0px 0px;
}
100% {
background-position: 500px 1000px, 400px 600px, 300px 800px, 200px 1200px, 100px 1150px, 600px 900px, 700px 1300px, 800px 1600px, 900px 1100px, 1000px 1400px;
}
}
JavaScript (scripts.js): (无需js)
结果
他给我的是一个图片移动替换。就是我提供带雪花的底图,动画就是底图连续动起来。如果你的底图不是单色,你会感觉到有多尴尬,如果你的地图是单色,你会感觉到在参加雪球阅兵式。好整齐。
第三次: 背景设置成了黑色,没看到雪花。为什么?
回答:
非常抱歉,我写的代码里应该考虑到这一点。由于雪花是白色的,如果将背景设置为黑色,白色的雪花会很难看到。
让我们将背景色更改为浅色,比如白色,这样雪花就能更清晰地显示出来。你可以在 CSS 文件中修改 body 的背景色:
body {
background: #fff; /* 更改背景色为白色 */
overflow: hidden;
}
运行后,你应该能够看到白色的雪花在浅色的背景上下落了。希望这次能够正常显示了!如果还有其他问题,欢迎随时问我。
第四次:根本就没看到雪花好不好
非常抱歉,感谢你的耐心。让我们尝试一种更直接的方式来实现下雪特效。我们将使用纯 JavaScript 在页面上创建元素并使其模拟雪花飘落的效果。
HTML 文件代码如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="styles.css">
<title>Snowfall Animation</title>
</head>
<body>
<div class="snowflakes-container"></div>
<script src="snowfall.js"></script>
</body>
</html>
然后,创建一个名为 “snowfall.js” 的 JavaScript 文件,并编写以下代码:
// 创建雪花元素
function createSnowflake() {
const snowflake = document.createElement('div');
snowflake.className = 'snowflake';
snowflake.style.left = Math.random() * window.innerWidth + 'px';
document.querySelector('.snowflakes-container').appendChild(snowflake);
// 设置雪花动画
const animation = snowflake.animate([
{ transform: 'translateY(-100%)' },
{ transform: 'translateY(100vh)' }
], {
duration: Math.random() * 3000 + 3000, // 随机速度
iterations: Infinity, // 无限循环
easing: 'linear'
});
return animation;
}
// 生成多个雪花元素
const numberOfSnowflakes = 100;
for (let i = 0; i < numberOfSnowflakes; i++) {
createSnowflake();
}
最后,创建一个名为 “styles.css” 的 CSS 文件,并添加以下样式:
body {
overflow: hidden;
margin: 0;
padding: 0;
background-color: #000; /* 设置背景色为黑色 */
}
.snowflakes-container {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
}
.snowflake {
position: absolute;
width: 10px; /* 雪花宽度 */
height: 10px; /* 雪花高度 */
background-color: #fff; /* 雪花颜色为白色 */
border-radius: 50%; /* 使用圆形雪花 */
pointer-events: none;
}
第五次:有两个问题,一个问题是刚开始雪是随机分布在页面的,第二个问题是雪花大小不一的,透明度也是有些许变化的。请修改
非常感谢您的反馈,让我们修复这些问题。首先,我们将确保雪花在页面宽度范围内随机分布,并且我们会统一设定雪花的大小和透明度。
首先,我们修改 “snowfall.js” 文件,使用 JavaScript 动态设置雪花元素的大小和位置:
// 创建雪花元素
function createSnowflake() {
const snowflake = document.createElement('div');
snowflake.className = 'snowflake';
const size = Math.random() * 20 + 5; // 随机大小
snowflake.style.width = size + 'px';
snowflake.style.height = size + 'px';
snowflake.style.left = Math.random() * window.innerWidth + 'px'; // 随机水平位置
snowflake.style.top = -10 + 'px'; // 初始垂直位置在屏幕上方
const opacity = Math.random() * 0.5 + 0.5; // 随机透明度
snowflake.style.opacity = opacity;
document.querySelector('.snowflakes-container').appendChild(snowflake);
// 设置雪花动画
const animation = snowflake.animate([
{ transform: 'translateY(-10px)' },
{ transform: 'translateY(' + window.innerHeight + 'px)' }
], {
duration: Math.random() * 3000 + 3000, // 随机速度
iterations: Infinity, // 无限循环
easing: 'linear'
});
return animation;
}
// 生成多个雪花元素
const numberOfSnowflakes = 100;
for (let i = 0; i < numberOfSnowflakes; i++) {
createSnowflake();
}
接下来,让我们修改 “styles.css” 文件,以确保所有雪花的大小和透明度都是相同的:
body {
overflow: hidden;
margin: 0;
padding: 0;
background-color: #000; /* 设置背景色为黑色 */
}
.snowflakes-container {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
}
.snowflake {
position: absolute;
background-color: #fff; /* 雪花颜色为白色 */
border-radius: 50%; /* 使用圆形雪花 */
pointer-events: none;
}
现在,当你刷新页面后,应该能够看到雪花在页面中随机飘落,而且它们的大小和透明度都是统一的。希望这次得到了您满意的结果。如果还有其他问题,欢迎继续和我交流。
第六次: 雪花的大小和 透明度不需要统一。
明白了,那我们将继续保持雪花的大小和透明度随机化。在这种情况下,我们只需确保雪花能够在页面内随机分布并飘落即可。
我们不需要修改 “snowfall.js” 文件,但是我们需要稍微修改 “styles.css” 文件,以便允许雪花的随机大小和透明度:
body {
overflow: hidden;
margin: 0;
padding: 0;
background-color: #000; /* 设置背景色为黑色 */
}
.snowflakes-container {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
}
.snowflake {
position: absolute;
background-color: #fff; /* 雪花颜色为白色 */
border-radius: 50%; /* 使用圆形雪花 */
pointer-events: none;
/* 随机大小和透明度 */
width: calc(5px + 20px * random());
height: calc(5px + 20px * random());
opacity: 0.3 + 0.7 * random();
}
现在,当你刷新页面后,应该能看到雪花在页面中随机飘落,它们的大小和透明度都是随机的。希望这次能够满足你的要求。如果还有其他问题,欢迎随时和我交流。
第七次:雪花产生和分布需要更加均匀,
好的,为了使雪花产生和分布更加均匀,我们可以微调 JavaScript 代码中雪花的生成逻辑。让我们来修改 “snowfall.js” 文件,以确保雪花能够更加均匀地产生和分布:
// 创建雪花元素
function createSnowflake() {
const snowflake = document.createElement('div');
snowflake.className = 'snowflake';
const size = Math.random() * 20 + 5; // 随机大小
snowflake.style.width = size + 'px';
snowflake.style.height = size + 'px';
const positionX = Math.random() * window.innerWidth; // 随机水平位置
const positionY = Math.random() * window.innerHeight; // 随机垂直位置
snowflake.style.transform = `translate(${positionX}px, ${positionY}px)`; // 设置位置
const opacity = Math.random() * 0.5 + 0.5; // 随机透明度
snowflake.style.opacity = opacity;
document.querySelector('.snowflakes-container').appendChild(snowflake);
// 设置雪花动画
const animation = snowflake.animate([
{ transform: `translate(${positionX}px, ${positionY}px)` },
{ transform: `translate(${positionX}px,${window.innerHeight + 20}px)` }
], {
duration: Math.random() * 3000 + 3000, // 随机速度
iterations: Infinity, // 无限循环
easing: 'linear'
});
return animation;
}
// 生成多个雪花元素
const numberOfSnowflakes = 200;
for (let i = 0; i < numberOfSnowflakes; i++) {
createSnowflake();
}
通过这个修改,雪花将更加均匀地分布在页面上,且它们的大小和透明度仍然是随机的。现在,刷新页面后,你应该能够看到雪花更加均匀地飘落在页面上了。希望这次的修改能够满足你的要求。如有其他问题,欢迎随时询问。
第八次:雪花的形状不对
理解您的需求,如果您想调整雪花的形状,我们可以使用不同的雪花形状来替代原先的圆形。让我来帮您修改 “styles.css” 文件,使得雪花的形状更加多样化:
body {
overflow: hidden;
margin: 0;
padding: 0;
background-color: #000; /* 设置背景色为黑色 */
}
.snowflakes-container {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
}
.snowflake {
position: absolute;
/* 使用不规则多边形作为雪花形状 */
clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 92%, 50% 70%, 21% 92%, 32% 57%, 2% 35%, 39% 35%);
pointer-events: none;
/* 随机大小和透明度 */
width: calc(5px + 20px * random());
height: calc(5px + 20px * random());
opacity: 0.3 + 0.7 * random;
background-color: #fff; /* 雪花颜色为白色 */
}
在这个修改后,雪花的形状将变成不规则的多边形,同时也保持了随机的大小和透明度。刷新页面后,您应该能够看到具有不同形状的雪花更加均匀地飘落在页面上。如您还有其他需求或问题,欢迎随时告诉我。
最后
我后边有提了一些要求,效果更差了。最后一次的效果差强人意。就是刚开始的那一下,感觉雪是被泼出来的。后边还好。勉强接受吧。或者你也可以 在此基础上修改。
或者你也可以尝试调教一下GPT ,让它聪明一点,哈哈哈。
祝大家圣诞快乐!
–