给图片添加

一、项目场景:

react + antd 4.x(此版本没有watermark水印),需要将后端传递的图片添加图片水印


二、水印添加:(此代码为修改好的)

javascript 复制代码
import imgs from './水印图片.png'; // 引入水印图片

...代码

const [url, setUrl] = useState(''); // 状态管理变量,记录图片最终的路径,vue中使用data来控制

...代码

// 水印
const img = document.createElement('img');
img.src = backUrl;  // 需要添加水印的图片地址
img.crossOrigin = 'Anonymous'; // 设置跨域属性,没设置可能报cors问题
img.onload = () => {
  const watermark = new Image();
  watermark.src = imgs;
  watermark.crossOrigin = 'Anonymous';  // 设置跨域属性
  // 此上面三行必须写在img.onload里面,不然会有显示问题
  watermark.onload = () => {
    const canvas = document.createElement('canvas');
    let imgWidth = img.width;
    let imgHeight = img.height;
    let waterWidth = watermark.width;
    let waterHeight = watermark.height;
    canvas.width = img.naturalWidth;
    canvas.height = img.naturalHeight;
    const ctx = canvas.getContext('2d');
    ctx.drawImage(img, 0, 0, imgWidth, imgHeight);
    if (imgHeight > waterHeight) {
      ctx.drawImage(watermark,0,0,waterWidth * (imgHeight / waterHeight),imgHeight);
    } else if (imgWidth > waterWidth) {
      ctx.drawImage(watermark,0,0,imgWidth,waterHeight * (imgWidth / waterWidth));
    } else {
      ctx.drawImage(watermark, 0, 0);
    }
    const watermarkedImgSrc = canvas.toDataURL('image/jpeg');
    setUrl(watermarkedImgSrc); 
    // 添加好水印的图片URL设置上去, vue的话直接用this赋值或者this.$set(待验证)
  };
};

...代码

三、问题描述:

1、水印添加问题

2、水印添加完成后显示问题

javascript 复制代码
// 水印
const img = document.createElement('img');
img.src = backUrl;  // 需要添加水印的图片地址
img.crossOrigin = 'Anonymous'; // 设置跨域属性,没设置可能报cors问题

const watermark = new Image();
watermark.src = imgs;
watermark.crossOrigin = 'Anonymous'; 

img.onload = () => {
  // ...代码
  watermark.onload = () => {
    // ...代码
  }
}

四、原因分析:

将watermark水印图片和img需要添加水印的图片同时创建了,以至于在img创建成功后watermark有可能还没有创建成功,导致没有进入watermark.onload的代码中


五、解决方案:

将watermark的创建放在img.onload中

相关推荐
续亮~1 小时前
6、Redis系统-数据结构-05-整数
java·前端·数据结构·redis·算法
顶顶年华正版软件官方3 小时前
剪辑抽帧技巧有哪些 剪辑抽帧怎么做视频 剪辑抽帧补帧怎么操作 剪辑抽帧有什么用 视频剪辑哪个软件好用在哪里学
前端·音视频·视频·会声会影·视频剪辑软件·视频剪辑教程·剪辑抽帧技巧
程序员云翼3 小时前
7-理财平台
java·vue.js·spring boot·后端·毕设
托尼沙滩裤4 小时前
【js面试题】js的数据结构
前端·javascript·数据结构
不熬夜的臭宝4 小时前
每天10个vue面试题(一)
前端·vue.js·面试
朝阳394 小时前
vue3【实战】来回拖拽放置图片
javascript·vue.js
不如喫茶去4 小时前
VUE自定义新增、复制、删除dom元素
前端·javascript·vue.js
长而不宰4 小时前
vue3+electron项目搭建,遇到的坑
前端·vue.js·electron
阿垚啊5 小时前
vue事件参数
前端·javascript·vue.js
加仑小铁5 小时前
【区分vue2和vue3下的element UI Dialog 对话框组件,分别详细介绍属性,事件,方法如何使用,并举例】
javascript·vue.js·ui