动态生成二维码并利用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"的引用. 第二步 ...
随机推荐
- 检查mysql表是否损坏的脚本
#!/bin/bash#此脚本的主要用途是检测mysql服务器上所有的db或者单独db中的坏表#变量说明 pass mysql账户口令 name mysql账号名称 data_path mysql目录 ...
- React-router4 第九篇 Ambiguous Matches 模糊匹配
https://reacttraining.com/react-router/web/example/ambiguous-matches 看了官方的例子,我准备把阮一峰老师的代码再粘贴一次..!!
- JSP请求重定向与请求转发的区别
请求重定向 客户端行为,response.sendRedirect(),从本质上讲等同于两次请求,前一次请求对象不会保存,地址栏URL会改变: 请求转发 服务器行为,request.getReques ...
- Java WEB开发环境搭建以及创建Maven Web项目
根据此链接博文学习配置: http://www.cnblogs.com/zyw-205520/p/4767633.html 1.JDK的安装 自行百度,(最好是jdk1.7版本的) 测试如下图,即完成 ...
- Codeforces 1114 简要题解
文章目录 A题 B题 C题 D题 E题 F题 传送门 然而这场div2div2div2没有什么难度比较大的题 A题 传送门 题意简述:三个人分别至少选x,y,zx,y,zx,y,z件物品,有三种物品数 ...
- 让photoshop cc 支持 webp格式
下载WebP.8bi文件,看PS cc 是32位还是64位,找到对应的文件. brushes8.com-2017-11-03_08-29-21_654098.7z 把 WebP.8bi 复制到pho ...
- android 动画学习
android动画基础简介及使用方法:http://www.cnblogs.com/ldq2016/p/5407061.html
- javabean的特点
javabean的三个基础条件 1.拥有私有的属性 2.共有的get,set方法 3.默认的构造方法
- 【repost】H5总结
1.新增的语义化标签: <nav>: 导航 <header>: 页眉 <footer>: 页脚 <section>:区块 <article> ...
- 阅读笔记4 我是一只IT小小鸟
经过一周连续三四天八小时以上坐在电脑前敲代码的“折磨”,去看看其他经受这些折磨的人的感受.这次读书笔记变成了逗比风,因为前几周认认真真记下书里写的重点内容,然后把学习的内容认真的记录下来的笔记被老师助 ...