图片二维码合成海报

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<head>
<title>QRCode</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no" />
<style>
#canbox{
	width: auto;
	height: 590px;
	position: fixed;
	top: 0;
	left: 0;
}
.canimg {
	width: auto;
	height: auto;
	position: fixed;
	top: 0;
	left: 0;
}
</style>
</head>
<body>
<div id="qrcode" style="display: none;">		
</div>
<div id="canbox">
<canvas id="myCanvas" width="" height=""></canvas>
</div>
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="qrcode.min.js"></script>
<script type="text/javascript" src="qrcode.js"></script>
<script type="text/javascript">
var qrcode = new QRCode("qrcode", {
    width : 100,
    height : 100,
    text: "https://blog.csdn.net/qq_41493250", 
	colorDark : "#000",
    colorLight : "#fff",
});
//画海报
var width = document.getElementById("canbox").offsetWidth; //宽度  
var height = document.getElementById("canbox").offsetHeight; // 高度
var c = document.getElementById("myCanvas");
c.width = width
c.height = 590
var ctx = c.getContext("2d");
//首先画上背景图
var img = new Image();
img.src = "1.png";
ctx.font = "19px Georgia";
//画上二维码
function convertCanvasToImage(canvas) {
	var image = new Image();
	image.src = canvas.toDataURL("image/png");
	return image;
}
var mycans = $('canvas')[0];
var codeimg = convertCanvasToImage(mycans)
var xw = width - 190
var xh = height - 260
console.log(mycans)
img.onload = function() { 
	ctx.drawImage(img, 0, 0, width, height); 
	ctx.drawImage(codeimg, xw, xh, 72, 72);

	setTimeout(function() {  //ios上可能会出现无法获取整个画布内容,加了个settimeout
		var bigcan = $('canvas')[0];
		let images = new Image();
		images.src = bigcan.toDataURL("image/png");
		$('.canimg').attr('src', bigcan.toDataURL("image/png"))
	}, 0)
}
</script>
</body>

在这里插入图片描述
实例下载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值