html5闪光效果,HTML5 canvas元素背景梦幻小星星闪烁特效
时间: 2023-08-03 14:18:18 浏览: 162
好的,我可以为您提供HTML5闪光效果和Canvas元素背景梦幻小星星闪烁特效的实现方法。以下是实现方法:
HTML5闪光效果:
1. 创建一个div元素,并在其中添加一个图片或者文字。
2. 使用CSS3的box-shadow属性来添加闪光效果,设置box-shadow的颜色为白色或者其他亮色,模糊值为5-10px,偏移值为0。
3. 使用CSS3的animation属性来实现闪光动画,设置animation的名称为“flash”,持续时间为1s,重复次数为infinite。
4. 在CSS样式中定义“flash”动画,使用@keyframes关键字定义动画的关键帧,从0%到50%设置box-shadow的模糊值为0,从50%到100%设置box-shadow的模糊值为10px。
示例代码如下:
```
<div class="shine">Hello World!</div>
<style>
.shine {
font-size: 30px;
color: #fff;
text-shadow: 0 0 5px #fff;
animation: flash 1s infinite;
}
@keyframes flash {
0% {
box-shadow: 0 0 0 #fff;
}
50% {
box-shadow: 0 0 0 #fff;
}
100% {
box-shadow: 0 0 10px #fff;
}
}
</style>
```
Canvas元素背景梦幻小星星闪烁特效:
1. 创建一个Canvas元素,并使用JavaScript获取其上下文。
2. 使用canvas的fillRect方法填充整个画布为黑色。
3. 定义一个Star对象,包含星星的位置、大小、颜色等属性。
4. 在Canvas上随机生成多个Star对象,使用fillRect方法绘制星星。
5. 使用setInterval函数不断重绘Canvas画布,每次重绘前都清除画布,然后更新所有星星的位置和大小,根据新的位置和大小重新绘制星星。
示例代码如下:
```
<canvas id="canvas"></canvas>
<script>
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var stars = [];
// 生成随机数
function random(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
// 定义星星对象
function Star() {
this.x = random(0, canvas.width);
this.y = random(0, canvas.height);
this.size = random(1, 3);
this.color = '#fff';
}
// 随机生成多个星星
for (var i = 0; i < 100; i++) {
stars.push(new Star());
}
// 绘制星星
function draw() {
ctx.fillStyle = '#000';
ctx.fillRect(0, 0, canvas.width, canvas.height);
for (var i = 0; i < stars.length; i++) {
var star = stars[i];
// 更新星星位置和大小
star.x += random(-1, 1);
star.y += random(-1, 1);
star.size += random(-1, 1);
// 限制星星的大小范围
if (star.size < 1) star.size = 1;
if (star.size > 3) star.size = 3;
// 绘制星星
ctx.fillStyle = star.color;
ctx.fillRect(star.x, star.y, star.size, star.size);
}
}
setInterval(draw, 30);
</script>
```
希望这些代码能够帮助您实现所需的效果。
阅读全文