使用uniapp开发app中遇到产品提出分享带有二维码图片的海报保存到相册需求、仅支持app端
1.首页页面的二维码生成无非就是拿到一个地址转成二维码,有很多很好用的插件可以用,我用的是tki-qrcode,用法自行百度。
2.这个方法主要是根据page.$getAppWebview()拦截可以获取页面栈中任意一个webview对象,然后通过这个对象的draw将webview内容绘制到一个对象里,通过uni.saveImageToPhotosAlbum进行保存
<!-- #ifdef APP-PLUS -->
<button class="info" @click="capture()">点击保存我哦~</button>
<!-- #endif -->
capture() {
var pages = getCurrentPages(); //获取当前页面信息
var page = pages[pages.length - 1];
// console.log(pages);
var bitmap = null;
var currentWebview = page.$getAppWebview();
bitmap = new plus.nativeObj.Bitmap('amway_img');
// 将webview内容绘制到Bitmap对象中
currentWebview.draw(bitmap, function() {
// console.log('截屏绘制图片成功');
//这里我将文件名用四位随机数拼接了,不然会出现当前图片替换上一张图片只能保存一张图片的问题
let rand = Math.floor(Math.random()*10000)
let saveUrl = '_doc/'+rand+'a.jpg'
bitmap.save(saveUrl, {}, function(i) {
// console.log('保存图片成功:' + JSON.stringify(i));
uni.saveImageToPhotosAlbum({
filePath: i.target,
success: function() {
// bitmap.clear(); //销毁Bitmap图片
uni.showToast({
title: '保存图片成功',
mask: false,
duration: 1500
});
}
});
}, function(e) {
console.log('保存图片失败:' + JSON.stringify(e));
});
}, function(e) {
console.log('截屏绘制图片失败:' + JSON.stringify(e));
});
//currentWebview.append(amway_bit);
},
3.保存之后会发现当前图片替换上一张图片只能保存一张图片。这是图片路径的文件名相同导致的问题,我是给保存的文件名加上随机数拼接就好了。代码里贴的有