vue 合成图片

目的:将二维码图片和背景图片合成变成一张图片
方法一:
引入依赖
cnpm install qrcanvas --save
cnpm install html2canvas --save
具体代码:
<!-- 分享图片生成 -->
<template>
<div class="container">
<div class="share-img">
<img :src="imgUrl" alt="分享图">
</div>
<div class="creat-img" ref="box">
<img src="../assets/images/activity/txvip.jpeg" alt="分享背景图">
<div id="qrcode" class="qrcode"></div>
</div>
</div>
</template> <script>
import { qrcanvas } from 'qrcanvas';
import html2canvas from 'html2canvas';
export default {
data () {
return {
imgUrl:'',
}
},
watch:{
imgUrl(val,oldval){
//监听到imgUrl有变化以后 说明新图片已经生成 隐藏DOM
this.$refs.box.style.display = "none";
}
},
created() {
let that = this;
that.$nextTick(function () {
//生成二维码
var canvas1 = qrcanvas({
data: decodeURIComponent(that.$route.query.url),
size:128
});
document.getElementById("qrcode").innerHTML = '';
document.getElementById('qrcode').appendChild(canvas1); //合成分享图
that.$indicator.open({
text: '正在生成图片...',
spinnerType: 'fading-circle'
});
html2canvas(that.$refs.box).then(function(canvas) {
that.imgUrl = URL.createObjectURL(that.base64ToBlob(canvas.toDataURL()))
setTimeout(()=>{
that.$indicator.close();
that.$toast({
message: '图片已生成,长按保存分享给你的好友吧',
position: 'middle',
duration: 3000
});
},2000)
});
})
}, methods: {
//base64转blob
base64ToBlob(code) {
let parts = code.split(';base64,');
let contentType = parts[0].split(':')[1];
let raw = window.atob(parts[1]);
let rawLength = raw.length; let uInt8Array = new Uint8Array(rawLength); for (let i = 0; i < rawLength; ++i) {
uInt8Array[i] = raw.charCodeAt(i);
}
return new Blob([uInt8Array], {type: contentType});
},
}
} </script>
<style lang='scss' scoped>
.creat-img{
img{
z-index: 3;
}
.qrcode{
position: absolute;
bottom: .15rem;
left: 50%;
margin-left: -64px;
z-index: 5;
}
} </style>
方法二:
html:
<template>
<div class="container">
<div id="imgBox" align="center"> </div>
</div>
</template>
js:
var qr_div = document.getElementById('qr_code').children[0];
var data = ['http://cdnzzz.vcgeek.cn/%E5%BE%AE%E4%BF%A1%E5%9B%BE%E7%89%87_20190118153442.jpg', '' + qr_div.src];
var base64 = [];
var c = document.createElement('canvas'),
ctx = c.getContext('2d'),
len = data.length;
c.width = 750;
c.height = 1334;
ctx.rect(0, 0, c.width, c.height);
ctx.fillStyle = '#fff';
ctx.fill();
drawing(0);
function drawing(n) {
if(n < len) {
var img = new Image;
img.crossOrigin = 'anonymous'; //解决跨域
img.src = data[n];
img.setAttribute("crossOrigin", 'Anonymous');
img.onload = function() {
if(n == 1) {
ctx.drawImage(img, 55, 1015, 200, 200); //121和129表示二维码距离背景图片左上角的X轴,Y轴,160表示生成的图片中二维码的大小
} else {
ctx.drawImage(img, 0, 0, c.width, c.height);
}
drawing(n + 1); //递归
}
} else {
console.log(c)
try {
//保存生成作品图片
base64.push(c.toDataURL("image/png",1)); //通过canvas.toDataURL转成base64.
document.getElementById('imgBox').innerHTML = '<img style="width:100%" class="invite_qrImg" src="' + base64[0] + '">';
// alert(base64[0].length)
} catch(e) {
//TODO handle the exception
console.log(alert(e))
}
}
}
html合成图片:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Html5 Canvas 实现图片合成</title> <style>
body{
text-align: center;
}
img {
border: solid 1px #ddd;
}
</style>
</head> <body>
<div align="center" style="display: none;">
<img src="./qr.png">
<img src="./qr.png">
</div>
<input type="button" value="一键合成" onclick="hecheng()">
<a href="" download id="downloadPic">下载合成图</a>
<div id="imgBox" align="center"> </div>
<script>
function hecheng() {
draw(function() {
document.getElementById('imgBox').innerHTML = '<img src="' + base64[0] + '">';
document.getElementById('downloadPic').href = base64[0];
})
} var data = ['qr.png', ''],
base64 = []; function draw(fn) {
var c = document.createElement('canvas'),
ctx = c.getContext('2d'),
len = data.length; console.log(data.length) c.width = 400;
c.height = 800;
ctx.rect(0, 0, c.width, c.height);
ctx.fillStyle = '#fff';
ctx.fill(); function drawing(n) {
if(n < len) {
var img = new Image;
//img.crossOrigin = 'Anonymous'; //解决跨域 img.src = data[n];
img.onload = function() {
if(n == 1) {
ctx.drawImage(img, 100, 100, 160, 160); //121和129表示二维码距离背景图片左上角的X轴,Y轴,160表示生成的图片中二维码的大小
} else {
ctx.drawImage(img, 0, 0, c.width, c.height);
} drawing(n + 1); //递归
}
} else {
//保存生成作品图片
base64.push(c.toDataURL()); //通过canvas.toDataURL转成base64.
//alert(JSON.stringify(base64));
fn();
}
}
drawing(0);
}
</script>
</body> </html>
vue 合成图片的更多相关文章
- [JavaScript] canvas 合成图片和文字
Canvas Canvas 是 HTML5 新增的组件,就像一个画板,用 js 这杆笔,在上面乱涂乱画 创建一个 canvas <canvas id="stockGraph" ...
- PHP合成图片、生成文字、居中对齐、画线、矩形、三角形、多边形、图片抗锯齿、不失真 高性能源码示例
function generateImg($source, $text1, $text2, $text3, $font = './msyhbd.ttf') { $date = '' . date ( ...
- ImageMagick利用蒙版合成图片
先看合成后的效果图. 需要的图片素材: 1.一张图片(335x600) 2.一张蒙版图片(335x600) 3.一张相框图片(335x600) 第一步,根据蒙板和图片,截取图片.而且所截取的图片之外的 ...
- PHP生成小程序二维码合成图片生成文字
这部分代码是写在项目上的代码,THINKPHP3.1如果迁移到其他的地方应该要稍稍改动一下以适合自己的项目 function get_bbox($text,$fsize,$ffile){ return ...
- $Django 路飞之小知识回顾,Vue之样式element-ui,Vue绑定图片--mounted页面挂载--路由携带参数
一 小知识回顾 1 级联删除问题 2 一张表关联多个表,比如有manytomanyfileds forignkey,基于对象查询存在的问题:反向查询的时候 表名小写_set.all()不知是哪个字段 ...
- 用imageMagick合成图片添加图片水印
用imageMagick合成图片的方式大致有三种, 使用convert命令加 +append或-append参数 使用convert命令加 -composite参数 直接使用composite命令来完 ...
- Django day 33 vue中使用element-ui的使用,课程的相关介绍,vue绑定图片,课程列表接口,课程详情页面
一:vue中使用element-ui的使用, 二:课程的相关介绍, 三:vue绑定图片, 四:课程列表接口, 五:课程详情页面
- 通过canvas合成图片
通过canvas合成图片 效果图 页面布局部分 两个图片以及一个canvas画布 <img src="https://qnlite.gtimg.com/qqnewslite/20190 ...
- php 合成图片,合成圆形图片
合成图片方法 <?php class Share { /* * 生成分享图片 * */ function cre_share_study_img(){ $auth = json_decode(b ...
随机推荐
- ajax技术实现登录判断用户名是否重复以及利用xml实现二级下拉框联动,还有从数据库中获得
今天学了ajax技术,特地在此写下来作为复习. 一.什么是ajax? 客户端(特指PC浏览器)与服务器,可以在[不必刷新整个浏览器]的情况下,与服务器进行异步通讯的技术 即,AJAX是一个[局部刷新 ...
- jar包冲突了?如何确定是和哪个jar包冲突了?
导读:工程编译的时候好好地,怎么一运行就报各种的NoSuch***Error,猜测可能是jar包冲突了,但是究竟是和哪个jar包冲突了呢. 关键词:jar包冲突,NoSuchFileldError,N ...
- 利用Code::Blocks搭建64位C++开发平台
0.前言 随着64位计算机的普及,编写64位程序成为程序员基本的要求.我在<体验Code::Blocks下的C++编程>中描述了利用Code::Blocks官方提供的封装了编译器的安装包( ...
- 【译】微软的Python入门教程(一)
Getting started with Python(Python入门) Overview 概述 The series of videos on Channel 9 is designed to h ...
- MongoDB 学习笔记之 Aggregation Pipeline实战实现inner join
Aggregation Pipeline实战实现inner join: leftT集合: comments集合: 现在我们要用aggregation实现inner join db.comments. ...
- linux下安装配置go语言环境
1,golang中国下载go源码 http://www.golangtc.com/download 请对应系统版本号,linux-amd64.tar.gz为64位系统(推荐) ,linux-386 ...
- abp(net core)+easyui+efcore实现仓储管理系统——EasyUI之货物管理四 (二十二)
abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...
- 从单片机到操作系统⑦——深入了解FreeRTOS的延时机制
>没研究过操作系统的源码都不算学过操作系统 # FreeRTOS 时间管理 时间管理包括两个方面:系统节拍以及任务延时管理. ## 系统节拍: 在前面的文章也讲得很多,想要系统正常运行,那么时钟 ...
- Tomcat7.0.40注册到服务启动报错error Code 1 +connector attribute sslcertificateFile must be defined when using ssl with apr
Tomcat7.0.40 注册到服务启动遇到以下几个问题: 1.启动报错errorCode1 查看日志如下图: 解决办法: 这个是因为我的jdk版本问题,因为电脑是64位,安装的jdk是32位的所以会 ...
- Java并发——线程间的等待与通知
前言: 前面讲完了一些并发编程的原理,现在我们要来学习的是线程之间的协作.通俗来说就是,当前线程在某个条件下需要等待,不需要使用太多系统资源.在某个条件下我们需要去唤醒它,分配给它一定的系统资源,让它 ...