Vue3中实现点击图片获取图片颜色

上传一张图片,点击图片的某个位置,获取点击位置图片的 16 进制颜色

下面是具体的实现代码

<template>
  <div class="apps">
    <img ref="image" src="./image.jpg" @click="getColor">
    <div :style="{ backgroundColor: color }" class="color-box"></div>
  </div>
</template>
<script setup>
  import { ref, getCurrentInstance } from 'vue';
  const color = ref('');
  const currentInstance = getCurrentInstance();
  const getColor = (e) => {
    // 获取图片元素
    const image = currentInstance.ctx.$refs.image;
    // 创建canvas元素
    const canvas = document.createElement('canvas');
    // 获取canvas绘图上下文
    const ctx = canvas.getContext('2d');
    // 设置canvas尺寸
    canvas.width = image.width;
    canvas.height = image.height;
    // 绘制图片到canvas中
    ctx.drawImage(image, 0, 0);
    // 获取鼠标点击的坐标
    const x = e.offsetX;
    const y = e.offsetY;
    // 获取canvas中的图片数据
    const data = ctx.getImageData(x, y, 1,1).data;
    // 计算颜色值
    const colorArr = [0, 0, 0];
    for (let i = 0; i < data.length; i += 4) {
      colorArr[0] += data[i];
      colorArr[1] += data[i + 1];
      colorArr[2] += data[i + 2];
    }
    colorArr[0] = Math.round(colorArr[0] / (data.length / 4));
    colorArr[1] = Math.round(colorArr[1] / (data.length / 4));
    colorArr[2] = Math.round(colorArr[2] / (data.length / 4));
    // 设置颜色值为响应式数据
    color.value = `rgb(${colorArr[0]}, ${colorArr[1]}, ${colorArr[2]})`;
  }
</script>
<style scoped lang="less">
.color-box {
  width: 50px;
  height: 50px;
  margin-top: 10px;
}
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值