给图片添加图片水印

这篇具有很好参考价值的文章主要介绍了给图片添加图片水印。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、项目场景:

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


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

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、水印添加完成后显示问题

// 水印
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中文章来源地址https://www.toymoban.com/news/detail-833984.html

到了这里,关于给图片添加图片水印的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 给图片添加水印

    2024年02月08日
    浏览(30)
  • Ueditor上传图片自动添加水印(通用图片文件)

    1、找到config.json,在配置文件中新增水印效果  2、找到php目录下的 action_uploads.php 文件 3、找到php同级目录下的类 uploadser.class.php    注意:以上代码会提示一个错误 imagealphablending() expects parameter 1 to be resource imagesavealpha() expects parameter 1 to be resource 在这个位置: 这个错误是因

    2024年02月12日
    浏览(39)
  • Moviepy模块之视频添加图片水印

    大家好,我是空空star,本篇给大家分享一下Moviepy模块之视频添加图片水印。 本篇使用的moviepy版本如下: Name: moviepy Version: 1.0.3 5.1 相对于视频的左上角 5.2 相对于视频的左下角 5.3 相对于视频的右上角 5.4 相对于视频的右下角 5.5 相对于视频的左中位置 5.6 相对于视频的正中位

    2023年04月08日
    浏览(28)
  • 一行Python代码给图片添加水印

    很多时候我们设计出一张精美的图片,但是一旦不加水印发到网上就会被他人抄袭,因此为了维护我们自身的版权,很多时候我们需要在一些图片或者视频中添加水印, 下面我将使用filestools模块分别在终端和python代码层面添加水印 。 1.下载ilestools模块 2.查看命令参数 在py

    2024年02月16日
    浏览(27)
  • ffmpeg在随机位置添加图片水印

     5秒添加一次 -i 输入的视频源 water.jpg放在跟视频一起的位置 temp.mp4是输出的视频

    2023年04月09日
    浏览(24)
  • Java实现视频与图片添加水印

    1、需要引入javacv依赖 2、代码实现

    2024年02月04日
    浏览(29)
  • 使用JavaScript给图片添加图片水印的前端实现方法

    当涉及图片处理时,JavaScript是一种强大的工具。在本篇博客中,我们将学习如何使用JavaScript来给图片添加水印,并将其封装成一个函数,以便在需要的时候重复使用。 在开始之前,确保你已经准备好了以下内容:         1.一张待添加水印的图片。         2.水印图片。

    2024年03月15日
    浏览(46)
  • Python代码学习之给图片添加文字或图片水印

    图片加水印有什么好处?在现今的数字化时代,网络上的图片泛滥,盗图现象也越来越严重。因此,在发布文章时,为了保护自己的原创作品版权,很多人选择使用水印来保护他们的图片。这样就能更好地做到: 1.版权保护:在商业用途的照片中添加水印可以帮助保护作者的

    2024年02月09日
    浏览(40)
  • 通过Python的PIL库给图片添加图片水印

    大家好,我是空空star,本篇给大家分享一下通过Python的PIL库给图片添加图片水印。 上一篇已经介绍过了PIL库是什么?安装PIL 、查看PIL版本,这里就不再介绍了。 这里我去C站首页找了一个,看起来是不是很酷。 7.1调整前 7.2调整后 8.1左上 8.2左下 8.3右上 8.4右下 8.5中间 其他位

    2023年04月19日
    浏览(44)
  • Demo: 给图片添加自定义水印并下载

    给图片添加自定义水印并下载

    2024年01月17日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包