微信小程序分享海报生成的实现方法


Posted in Javascript onDecember 10, 2018

为了吸引更多的用户,设计好一个分享海报还是很有必要的。而小程序要生成一个海报还是有点坑的,下面分享下我们打卡小程序的一些经验。

分享海报的效果图如下:

微信小程序分享海报生成的实现方法

制作要求:

  • 海报以弹窗形式展现,各种手机型号都可以正常显示
  • 海报的内容由背景图、日期、随机的名言警句、活动的二维码及用户的参加活动的信息
  • 海报保存的图片大小为 iphone 6 的两倍图(750 * 1334)

由于看到的弹窗图片与保存的图片是两种大小,所以一开始看了些网上的其他教程,建议是搞两个 canvas 一个大的一个小的。实际过程中,采用了一个大的 canvas ,让其偏离视窗显示区域(不可见)并生成临时文件,弹窗的图片再使用 img 组件,引入临时文件,设置其高度;而保存的时候则直接下载临时文件。

虽然是实现了,但是后来在优化的过程中,这个方案也重新设计了。下面具体介绍下优化过的方案:

  • 优先使用一个 canvas 绘制二维码;
  • 弹窗的图片即为一个 canvas;
  • 分享的图片为该 canvas 导出的大图片;
  • 为了达到最佳效果,名言警句的换行录入时就处理好。

设计弹窗的图片比例

由于最后海报的图片大小为 iphone 6 的两倍图(750 * 1334),所以这里弹窗的图片也即是 canvas 的大小,设计为对应的尺寸的某个比例。

弹窗图片的高度 = 视窗的高度 - 上下留白 - 按钮的高度 - 图片与按钮的距离
imgHeight = 100vh - 40rpx * 2 - 50rpx - 15rpx

弹窗图片的宽度 /  弹窗图片的高度 = 750 / 1334
弹窗图片的宽度 = (750 / 1334) * 弹窗图片的高度

由于像素只能是整数,所以这样绘制出来的图片可能底部会有1px的空白,所以在设置高度的时候可以再减掉 1px,这不会影响视觉效果。

绘制背景图

如果是网络图片,绘制背景图之前一定要先下载该图片,可通过 wx.getImageInfo wx. downloadFile 下载图片,下载成功后将其塞进临时地址,然后使用 wx canvas 的 drawImage 绘制。注意图片的格式不能是 gif。

绘制二维码

绘制二维码换了好几个库,每个在安卓下面生成的二维码都会频现失败。查了好些资料,说是安卓绘制的时候要设置个 setTimeout,于是最终选择了weapp-qrcode,修改了其绘制的函数,增加了setTimeout(还真别说,加上二维码绘制就成功了)。

ctx.draw(false, function (e) {
  setTimeout(() => { // 修改增加的
    options.callback && options.callback(e)
  }, 20);
})

另:目前这些绘制小程序二维码的库都是在一个单独的新 canvas 中完成的,只要对源码稍作修改,就可以提供另一个接口,直接在一个现有的 canvas (表示 canvas 中一开始绘制了其他内容) 中绘制。

如果二维码扫不出来,则表示二维码绘制出了问题。但安卓微信 6.7.2 版本本身有个 bug,二维码本身是没有问题,它却不能识别。不过升级下微信版本就好了。

保存图片

  • 先要获取用户是否开启用户授权相册
  • 如果没有权限,则弹窗提示开通权限,如果有权限直接调用 saveImageToPhotosAlbum 接口保存图片
  • 如果弹窗提示接受开通权限,则调用 saveImageToPhotosAlbum 接口保存图片
  • 如果弹窗提示拒绝则再次弹窗是否去设置开通权限,如果是则进入设置权限

性能注意

经实践测试整个绘制过程其实还是很快的,但是如果有保存临时文件操作( wx.canvasToTempFilePath ),那么这个操作一般得占一半时间左右。除此之外,有个 measureText api,用来测量文字的长度,这个在实现自动换行的时候用得到,但是比较耗性能。

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

Javascript 相关文章推荐
Ext.FormPanel 提交和 Ext.Ajax.request 异步提交函数的区别
Nov 12 Javascript
多种方法实现JS动态添加事件
Nov 01 Javascript
javascript实现支持移动设备画廊
Aug 24 Javascript
JS函数的定义与调用方法推荐
May 12 Javascript
jQuery筛选数组之grep、each、inArray、map的用法及遍历json对象
Jun 20 Javascript
js 获取站点应用名的简单实例
Aug 18 Javascript
让编辑器支持word复制黏贴、截屏的js代码
Oct 17 Javascript
Jquery Easyui菜单组件Menu使用详解(15)
Dec 18 Javascript
JS完成画圆圈的小球
Mar 07 Javascript
vue 表单之通过v-model绑定单选按钮radio
May 13 Javascript
基于iview的router常用控制方式
May 30 Javascript
小程序双头slider选择器的实现示例
Mar 31 Javascript
jQuery选择器选中最后一个元素,倒数第二个元素操作示例
Dec 10 #jQuery
详解Angular Forms中自定义ngModel绑定值的方式
Dec 10 #Javascript
jQuery+css last-child实现选择最后一个子元素操作示例
Dec 10 #jQuery
微信小程序与后台PHP交互的方法实例分析
Dec 10 #Javascript
引入外部js脚本加载慢与页面白屏问题的解决
Dec 10 #Javascript
JQuery Ajax执行跨域请求数据的解决方案
Dec 10 #jQuery
发布Angular应用至生产环境的方法
Dec 10 #Javascript
You might like
php session_start()出错原因分析及解决方法
2013/10/28 PHP
浅谈PHP中单引号和双引号到底有啥区别呢?
2015/03/04 PHP
Swoole源码中如何查询Websocket的连接问题详解
2020/08/30 PHP
基于jQuery的树控件实现代码(asp.net+json)
2010/07/11 Javascript
深入document.write()与HTML4.01的非成对标签的详解
2013/05/08 Javascript
网站如何做到完全不需要jQuery也可以满足简单需求
2013/06/27 Javascript
Javascript中Event属性搜集整理
2013/09/17 Javascript
JavaScript学习心得之概述
2015/01/20 Javascript
PHP 数组current和next用法分享
2015/03/05 Javascript
关于HTTP传输中gzip压缩的秘密探索分析
2018/01/12 Javascript
vue父组件异步获取数据传给子组件的方法
2018/07/26 Javascript
在 Vue-CLI 中引入 simple-mock实现简易的 API Mock 接口数据模拟
2018/11/28 Javascript
JS+php后台实现文件上传功能详解
2019/03/02 Javascript
基于layui框架响应式布局的一些使用详解
2019/09/16 Javascript
[02:41]DOTA2英雄基础教程 冥魂大帝
2014/01/16 DOTA
[01:27:43]VGJ.S vs TNC Supermajor 败者组 BO3 第三场 6.6
2018/06/07 DOTA
python使用循环实现批量创建文件夹示例
2014/03/25 Python
Python编程入门的一些基本知识
2015/05/13 Python
Queue 实现生产者消费者模型(实例讲解)
2017/11/13 Python
使用python+whoosh实现全文检索
2019/12/09 Python
python利用opencv实现SIFT特征提取与匹配
2020/03/05 Python
Python搭建Keras CNN模型破解网站验证码的实现
2020/04/07 Python
通过实例了解Python异常处理机制底层实现
2020/07/23 Python
Python logging模块原理解析及应用
2020/08/13 Python
Scrapy项目实战之爬取某社区用户详情
2020/09/17 Python
详解CSS3 filter:drop-shadow滤镜与box-shadow区别与应用
2020/08/24 HTML / CSS
Under Armour安德玛中国官网:美国高端运动科技品牌
2018/03/09 全球购物
计算机专业毕业生自荐信
2013/12/31 职场文书
外贸业务员工作职责
2014/01/06 职场文书
新学期开学寄语
2014/01/18 职场文书
JAVA程序员自荐书
2014/01/30 职场文书
公司门卫工作职责
2014/06/28 职场文书
授权委托书怎么写
2014/09/25 职场文书
个人租房协议书
2014/11/28 职场文书
傅雷家书读书笔记
2015/06/29 职场文书
MySQL连表查询分组去重的实现示例
2021/07/01 MySQL