动态生成二维码并利用canvas合成出一张图片(类似海报、分享页)
在前端开发并打算推广一个APP的时候,推广页是免不了的,而推广页的展示方式一般是给人家一个二维码,让别人自己去安装APP,这样前段任务也达到了,这次写这篇文章的原因主要还是总结一下,其中有很多不完善的地方,还是请各位指教了:-)。
为了做出一张让人满意分享页,页面上的数据有些当然是需要动态展示的,具体展示效果如下图(部分内容不便展示,见谅):

下面说下需要用到的工具,就两个:
1.能动态生成二维码的插件qrcode 2.canvas画布
因为小编用的vue框架具体引入为:
import qrcode from '@xkeshi/vue-qrcode'
可以看到效果图上的数据展示部分一个是二维码一个是我的用户名,下面我们开始上代码。
html:
<qrcode tag="img" id="img" :value="qrCodeUrl" :options="{ size: 120 }" name="img"></qrcode>
<canvas id="myCanvas" width="400vw" height="711vw"></canvas>
<img :src="newSrc" class="newImage" v-if="newSrc" id="newImage">
为何多加了一个空图片呢?是为了把最后合成的图片canvas变为img图片格式,这样就可以进行处理长按识别、保存图片等处理了。
js:
created: function () {
if (this.qrImg == '' || this.qrImg == null) {
if (vueCookie.get('nickname')) {
this.recommendCode = vueCookie.get('userID')
this.nickname = vueCookie.get('nickname') + '邀您加入'
this.qrCodeUrl = "您要存放的二维码信息"
setTimeout(function () {
that.drawImage()
}, )
} else {
request.get('/ffq/user',{}).then((response) => {
let responseData = response.data.data
this.nickname = responseData.nickname + '邀您加入'
let recommendCode = responseData.recommend_code
this.recommendCode = responseData.user_id
this.qrCodeUrl = "您要存放的二维码信息"
setTimeout(function () {
that.drawImage()
}, )
}).catch((ex) => {
this.$router.push({name: 'Login'})
})
}
}
},
上面这段代码是展示我们动态设置的二维码信息及缓存我的个人信息(这部分看个人随意添加就不注重说明了)。
下面开始就是重点了--------->>>>将背景图与生成的二维码合成展示为一张图片。
methods{
drawImage() {
let canvas1 = document.getElementsByTagName('canvas')[0]
let canvas2 = document.getElementById('myCanvas')
let cans = document.getElementById('img')
let cas1 = canvas1.getContext('2d')
let cas2 = canvas2.getContext('2d')
let img1 = new Image()
let img2 = new Image()
// img1.src = canvas1.toDataURL('images/png', 1)
img1.src = cans.src;
img2.src = '/static/images/qr-code.png'
var that = this
img2.onload = function () {
cas2.drawImage(img2, 0, 0, 400, 712)
cas2.font = '20px Georgia'
cas2.textAlign = 'center'
cas2.fillStyle = 'white';
cas2.fillText(that.nickname, 200, 630);
cas2.drawImage(img1, 104, 378, 194, 194);
that.newSrc = canvas2.toDataURL('images/png', 1)
}
}
首先进行下代码说明,前面定义的canvas1、canvas2是一张图片,是为了后面可以合成图片,之后隐藏的路径开始时是可以的,后来不知怎的就找不到了,预算就用了最原始的获取路径,剩下的就是作图了,当背景图加载好的时候把二维码按照位置画上去就行了,但是,我们得出的最终图片是canvas类型的,这个部分在我测试的时候长按并不会出现任何反应,最后的一行代码是我的解决方案,有其他的方案或者我有出错的地方,欢迎指教!!!。
动态生成二维码并利用canvas合成出一张图片(类似海报、分享页)的更多相关文章
- Jquery.Qrcode在客户端动态生成二维码并添加自定义Logo
0 Jquery.Qrcode简介 Jquery.Qrcode.js是一个在浏览器端基于Jquery动态生成二维码的插件,支持Canvas和Table两种渲染方式,它的优点是在客户端动态生成,减轻了服 ...
- js动态生成二维码
一.使用jquery.qrcode生成二维码 1.首先在页面中加入jquery库文件和qrcode插件 <script type="text/javascript" src= ...
- jquery动态生成二维码添加自定义logo
动态生成二维码中间带logo. jquery.qrcode.js 动态生成二维码api很简单. 引入jquer(版本任意),引入jquery.qrcode.js 不需要中间带logo这样就可以了.带l ...
- qrcode.js 动态生成二维码
用qrcode.js动态生成二维码图片非常简单,只需要引入qrcode.js即可使用,而且可以自定义图片大小.背景色等信息. 1.jsp代码---页面头部引入qrcode.js,jquery文件可选 ...
- thinkphp5动态生成二维码实例总结
thinkphp5关于动态生成二维码类库总结: 遇到的最大问题如下:我想大部分人也碰到过,所有觉得有必要总结下: thinkphp5提示找不到Qrcode类,可是自己明明都放置到了,vendor 目录 ...
- 动态生成二维码插件 jquery.qrcode.js
前段时间做项目,需要动态生成一个二维码,于是就在网上找了一下发现一个jquery插件jquery.qrcode.js,所以今天就简单说一下这个插件的使用: jquery.qrcode.js是依赖jqu ...
- js动态生成二维码图片
1.html代码 <div id="qrcode" style="width:200px; height:200px;position: fixed;bottom: ...
- 小程序动态生成二维码,生成image图片
前端: <image src="{{img_usrl}}" style="width:100%;height:104px;" bindlongtap=&q ...
- 使用QRCode生成二维码
第一步: 获取QRCode组件 可以通过vs的nuget管理安装Gma.QrCodeNet, 也可以直接添加"Gma.QrCodeNet.Encoding.dll"的引用. 第二步 ...
随机推荐
- PHP并发之Swoole
<?php /** * Created by PhpStorm. * User: zhezhao * Date: 2016/10/20 * Time: 10:51 */ $url_arr = a ...
- 网站开发,推荐使用SuperSlide 插件-Tab标签切换,图片滚动,无缝滚动,焦点图
SuperSlide 致力于解决网站大部分特效展示问题,使网站代码规范整洁,方便维护更新.网站上常用的“焦点图/幻灯片”“Tab标签切换”“图片滚动”“无缝滚动”等只需要一个SuperSlide即可解 ...
- AutoCAD开发3--修改文字图层,颜色
Dim pText As AcadText Dim pColor1 As AcadAcCmColor Set pColor1 = Application.GetInterfaceObject(&quo ...
- canvasJS
- ubuntu中给python3安装opencv
一.安装相关工具包******注意:以下3,4,5,6为可选项,根据需求安装******1.更新库 sudo apt-get update sudo apt-get upgrade 2.安装从源码构建 ...
- Alpha 冲刺 (10/10)
队名 火箭少男100 组长博客 林燊大哥 作业博客 Alpha 冲鸭鸭鸭鸭鸭鸭鸭鸭鸭鸭! 成员冲刺阶段情况 林燊(组长) 过去两天完成了哪些任务 协调各成员之间的工作 测试整体软件 展示GitHub当 ...
- 甲方安全建设之office365邮箱弱口令检测
甲方安全建设之office365邮箱弱口令检测 信息收集 资产范围 资产列表总数是521 抓包后发现只有102 一番测试之后发现控制Response的关键在于MaxEntriesReturned字段, ...
- wx:for类表渲染
列表渲染 wx:for 在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件. 默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item < ...
- Alpha冲刺 - (5/10)
Part.1 开篇 队名:彳艮彳亍团队 组长博客:戳我进入 作业博客:班级博客本次作业的链接 Part.2 成员汇报 过去两天完成了哪些任务 基于ssm框架的前后端交互测试,结合微信小程序demo 展 ...
- Associative Containers
Notes from C++ Primer Associative containers differ in fundamental respect from the sequential conta ...