canvas将两张图片合并成一张图片并下载

用canvas将两张图片合并成一张图并下载(react)

  • 图片合成部分
generateCodePic = () => {
    this.downloadImg();
};
downloadImg() {
    var canvas = document.createElement('canvas');
    console.log(canvas);
    canvas.width = 600;
    canvas.height = 800;
    if (!canvas.getContext) return;
    var ctx = canvas.getContext('2d');
    var imgBack = this.bgImg; // 创建img元素
    imgBack.setAttribute('crossOrigin', 'anonymous');
    console.log(imgBack);
    ctx.drawImage(imgBack, 0, 0, 600, 800);
    var img = this.codeImg;
    img.setAttribute('crossOrigin', 'anonymous');
    ctx.drawImage(img, 100, 150, 400, 400);
    const canvasUrl = canvas.toDataURL('image/png');
    downLoad(canvasUrl);
    function downLoad(url) {
      var oA = document.createElement('a');
      oA.download = '二维码邀请函'; // 设置下载的文件名
      oA.href = url;
      document.body.appendChild(oA);
      oA.click();
      oA.remove(); // 下载之后把创建的元素删除
    }
  }

  • render函数内容
<img src={code} ref={ref => (this.codeImg = ref)} />
<img
	src={require('@/assets/img/invite.png')}
	ref={ref => (this.bgImg = ref)}
	style={{ display: 'none' }}
/>
<Button type="primary" onClick={this.generateCodePic}>
点击生成二维码邀请函
</Button>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值