微信小程序canvas绘制圆角base64图片的实现


Posted in Javascript onAugust 18, 2019

接口返回base64格式小程序二维码,以往的做法是需要再调一个接口去拿到jpg/png格式的图片。如果没有这个接口呢,是不是也可以?然而小程序canvas并不支持直接使用base64绘制,好在小程序的文件系统提供了方法,可以把base64经过进一步处理转成本地图片。

获取base64格式图片

getXcxQrcode() {
 wx.request({
 url: app.globalData.globalUrl + "/get_wx_code",
 data: {
 token: app.globalData.weixin_token,
 scene: app.globalData.page_key,
 page: "pages/index/index"
 },
 success: (res) => {
 if (data.data.success) {
  this.base64src(data.data)
 }
 }
 })
}

base64格式图片转换成本地图片

base64src(base64data) {
 const filePath = `${wx.env.USER_DATA_PATH}/tmpbase64.png`;
 const buffer = wx.base64ToArrayBuffer(base64data.buffer);
 let that = this;
 fsm.writeFile({
  filePath,
  data: buffer,
  encoding: 'binary',
  success() {
   that.setData({
    qrcodeUrl: filePath // 得到http://usr/tmpbase64.png
   })
  },
  fail() {
   reject(new Error('ERROR_BASE64SRC_WRITE'));
  },
 });
},

使用获得的本地图片绘制圆角二维码

var qrW = 150; //绘制的二维码宽度
var qrH = 150; //绘制的二维码高度
var qr_x = 540; //绘制的二维码在画布上的位置
var qr_y = 960; //绘制的二维码在画布上的位置
ctx.save();

ctx.beginPath(); //开始绘制
//先画个圆  前两个参数确定了圆心 (x,y) 坐标 第三个参数是圆的半径 四参数是绘图方向 默认是false,即顺时针
ctx.arc(qrW / 2 + qr_x, qrH / 2 + qr_y, qrW / 2, 0, Math.PI * 2, false);

ctx.clip(); //画好了圆 剪切 原始画布中剪切任意形状和尺寸。一旦剪切了某个区域,则所有之后的绘图都会被限制在被剪切的区域内 这也是我们要save上下文的原因
ctx.drawImage(this.data.qrcodeUrl, qr_x, qr_y, qrW, qrH);
ctx.draw()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js获取变量
Aug 24 Javascript
基于Jquery的跨域传输数据(JSONP)
Mar 10 Javascript
javascript同页面多次调用弹出层具体实例代码
Aug 16 Javascript
Extjs根据条件设置表格某行背景色示例
Jul 23 Javascript
JS实现淡蓝色简洁竖向Tab点击切换效果
Oct 06 Javascript
javascript跨域请求包装函数与用法示例
Nov 03 Javascript
[原创]SyntaxHighlighter自动识别并加载脚本语言
Feb 07 Javascript
微信小程序与php 实现微信支付的简单实例
Jun 23 Javascript
Vue-CLI 3.X 部署项目至生产服务器的方法
Mar 22 Javascript
layer弹出层自适应高度,垂直水平居中的实现
Sep 16 Javascript
详解如何修改 node_modules 里的文件
May 22 Javascript
何时/使用 Vue3 render 函数的教程详解
Jul 25 Javascript
Node.js从字符串生成文件流的实现方法
Aug 18 #Javascript
微信公众号生成新浪短网址的实现(快速生成)
Aug 18 #Javascript
js 实现 list转换成tree的方法示例(数组到树)
Aug 18 #Javascript
详解ES6 Promise的生命周期和创建
Aug 18 #Javascript
vue-cli3配置与跨域处理方法
Aug 17 #Javascript
vue中获取滚动table的可视页面宽度调整表头与列对齐(每列宽度不都相同)
Aug 17 #Javascript
vue 使用element-ui中的Notification自定义按钮并实现关闭功能及如何处理多个通知
Aug 17 #Javascript
You might like
php生成随机密码的几种方法
2011/01/17 PHP
非常好用的两个PHP函数 serialize()和unserialize()
2012/02/04 PHP
PHP函数func_num_args用法实例分析
2015/12/07 PHP
php抽奖概率算法(刮刮卡,大转盘)
2020/04/17 PHP
详解php中的implements 使用
2017/06/13 PHP
PHP将整数数字转换为罗马数字实例分享
2019/03/17 PHP
javascript学习随笔(使用window和frame)的技巧
2007/03/08 Javascript
extjs 学习笔记(一) 一些基础知识
2009/10/13 Javascript
javascript面向对象之Javascript 继承
2010/05/04 Javascript
基于jquery异步传输json数据格式实例代码
2013/11/23 Javascript
浅析JavaScript原型继承的陷阱
2013/12/03 Javascript
ExtJS4 表格的嵌套 rowExpander应用
2014/05/02 Javascript
IE6 hack for js 集锦
2014/09/23 Javascript
jQuery简单实现隐藏以及显示特效
2015/02/26 Javascript
js实现横向百叶窗效果网页切换动画效果的方法
2015/03/02 Javascript
基于BootStrap Metronic开发框架经验小结【四】Bootstrap图标的提取和利用
2016/05/12 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
2017/02/20 Javascript
JS实现异步上传压缩图片
2017/04/22 Javascript
Nodejs中使用phantom将html转为pdf或图片格式的方法
2017/09/18 NodeJs
Vue中v-show添加表达式的问题(判断是否显示)
2018/03/26 Javascript
vue props 一次传多个值实例
2020/07/22 Javascript
Python连接mssql数据库编码问题解决方法
2015/01/01 Python
浅析Python多线程下的变量问题
2015/04/28 Python
python字符串常用方法
2018/06/14 Python
python实现公司年会抽奖程序
2019/01/22 Python
Django框架中序列化和反序列化的例子
2019/08/06 Python
python基于opencv实现人脸识别
2021/01/04 Python
美国开幕式潮店:Opening Ceremony
2018/02/10 全球购物
乌克兰珠宝大卖场:Zlato.ua
2020/09/27 全球购物
水产养殖学应届生求职信
2013/09/29 职场文书
2014年党员学习“三严三实”思想汇报
2014/09/15 职场文书
学校推普周活动总结
2015/05/07 职场文书
教师聘用意向书
2015/05/11 职场文书
MySQL系列之六 用户与授权
2021/07/02 MySQL
游戏《铁拳》动画化!2022年年内播出
2022/03/21 日漫
Win11怎么添加用户?Win11添加用户账户的方法
2022/07/15 数码科技