canvas-vue彩色丝带展示
时间: 2023-10-12 10:19:11 浏览: 97
可以使用Vue和Canvas来实现彩色丝带展示效果。以下是一个简单的实现示例:
HTML部分:
```html
<canvas ref="canvas"></canvas>
```
Vue部分:
```javascript
export default {
mounted() {
const canvas = this.$refs.canvas;
const ctx = canvas.getContext('2d');
const colors = ['#FFA07A', '#FFB6C1', '#87CEEB', '#FFD700', '#ADD8E6'];
// 将canvas的宽度设置为父元素的宽度
canvas.width = canvas.parentNode.offsetWidth;
// 定义一个彩色丝带的类
class Ribbon {
constructor() {
this.x = 0;
this.y = Math.random() * canvas.height;
this.color = colors[Math.floor(Math.random() * colors.length)];
this.speed = Math.random() * 2 + 1;
this.offset = Math.random() * 100;
}
update() {
this.x += this.speed;
this.y = Math.sin(this.x / 50 + this.offset) * 50 + canvas.height / 2;
if (this.x > canvas.width) {
this.x = -100;
}
}
draw() {
ctx.beginPath();
ctx.moveTo(this.x, this.y);
ctx.lineTo(this.x + 100, this.y + 100);
ctx.strokeStyle = this.color;
ctx.lineWidth = 2;
ctx.stroke();
}
}
// 创建多个彩色丝带并进行动画绘制
const ribbons = [];
for (let i = 0; i < 10; i++) {
const ribbon = new Ribbon();
ribbons.push(ribbon);
}
function loop() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
ribbons.forEach((ribbon) => {
ribbon.update();
ribbon.draw();
});
requestAnimationFrame(loop);
}
loop();
},
};
```
在mounted()生命周期函数中,我们首先获取canvas元素和其上下文,然后将canvas的宽度设置为与其父元素相同。接着我们定义了一个Ribbon类,该类包含了x、y、color、speed、offset等属性,以及update()和draw()方法,用于更新彩色丝带的位置和绘制彩色丝带。最后,我们创建多个彩色丝带并进行动画绘制。
在loop()函数中,我们首先调用了clearRect()方法来清空canvas画布,然后遍历所有彩色丝带,对每个丝带进行更新和绘制。最后,我们使用requestAnimationFrame()方法来不断循环调用loop()函数,实现动画效果。
这就是一个简单的canvas-vue彩色丝带展示的实现方法。
阅读全文