<template>
<div class="container">
<img :src="originalImage" class="original" @load="convertToGrayscale">
<img :src="grayscaleImage" class="grayscale" v-show="grayscale">
</div>
</template>
<script>
export default {
data() {
return {
originalImage: '/images/pic.jpg',
grayscaleImage: '',
grayscale: false
};
},
methods: {
convertToGrayscale() {
let canvas = document.createElement('canvas');
let ctx = canvas.getContext('2d');
let img = document.querySelector('.original');
canvas.width = img.width;
canvas.height = img.height;
ctx.drawImage(img, 0, 0);
let imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
let data = imageData.data;
for (let i = 0; i < data.length; i += 4) {
let brightness = (data[i] + data[i + 1] + data[i + 2]) / 3;
data[i] = brightness;
data[i + 1] = brightness;
data[i + 2] = brightness;
}
ctx.putImageData(imageData, 0, 0);
this.grayscaleImage = canvas.toDataURL();
this.grayscale = true;
}
}
};
</script>
<style scoped>
.container {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
}
.original, .grayscale {
max-width: 300px;
}
.grayscale {
display: none;
}
</style>
上面是“如何在Vue中实现图片的灰度处理?”的全面内容,想了解更多关于 vuejs 内容,请继续关注web建站教程。
当前网址:https://ipkd.cn/webs_12894.html
workflows工作流
一碗热气腾腾的拉面ComfyUI工作流
一只蚊子被嵌在琥珀中ComfyUI工作流
乡村枯树黄花comfyui工作流
一张超现实主义美女照片ComfyUI工作流
五颜六色的球花comfyui工作流
一个威武雄壮的战士ComfyUI工作流
一个浑身皮毛看起来像丘巴卡的3d动漫人物
一座巨大的野兽派建筑漂浮在热带风景中的贫民
猜你喜欢
声明:本站提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请发送到邮箱:admin@ipkd.cn,我们会在看到邮件的第一时间内为您处理!

css3动画loading效果
利用html5+css3实现滚雪球效果(附代码)
一起去看流星雨(代码)
canvas黑洞漩涡(canvas+js)
如何利用svg做一个有趣的loading动画加载
HTML5 Canvas 刻度尺
3d文字动画效果
3d文字360度旋转










