小程序图片长按识别功能的实现方法
程序员文章站
2023-10-26 17:20:46
背景
今天,做的小程序项目要求,个人中心的客服图片在用户长按时可以识别其二维码
在百度无果,参考小程序官方文档后,发现:
1.文档中有一句提示:
"...
背景
今天,做的小程序项目要求,个人中心的客服图片在用户长按时可以识别其二维码
在百度无果,参考小程序官方文档后,发现:
1.文档中有一句提示:
"image组件中二维码/小程序码图片不支持长按识别,仅在 wx.previewimage 中支持长按识别"
2.即便实现了 “wx.previewimage” 效果,但依旧是不支持二维码识别的
附录文档位置:小程序图片长按识别
代码设计
好在这也是一个不错的知识点,在此进行一番实现流程的记录,欢迎指摘.
①. wxml 页面元素设计
作为引导界面,只需放置一张图片即可,以我的代码为例
//# 使用简单的实现方式,直接赋值一个图片链接得了 <image src="https://img.fetow.com/public/index/images/shewm.jpg" mode="widthfix" data-src="https://img.fetow.com/public/index/images/shewm.jpg" bindtap="previewimage"></image>
②. js 文件实现 “previewimage”方法
在对应的 js 文件中,添加了如下的方法
/** * 图片预览方法 * 此处注意的一点就是,调用 "wx.previewimage"时,第二个参数要求为数组形式哦 * 当然,做过图片上传功能的应该会注意到,如果涉及到多张图片预览,图片链接数组集合即为参数 urls! */ previewimage: function(e) { var current = e.target.dataset.src; wx.previewimage({ current: current, urls: [current] }) },
③. 实现效果
可以发现,下图中是没有“识别图中二维码”的选项
如果发送给了好友或者自行保存后,在微信中打开的并长按的效果如下:
出现问题:
1.服务器上发送过来的图片路径直接插进ctx.drawimage 上,手机上显示不了。
解决方案:利用wx.downloadfile 将图片下载再保存好这个新图片路径,然后放到ctx.drawimage 上
//下载图片 onshow1: function (object) { let _this = this; _this.setdata({ isshowcav: true }) wx.downloadfile({ url: object.avatarurl, success: function (sres) { _this.setdata({ canvasuserpic: sres.tempfilepath }); wx.downloadfile({ url: object.show_img, success: function (sres1) { _this.setdata({ canvasshowimg: sres1.tempfilepath }); _this.canvas(object); } }) } }) },
2.canvas出现在手机上的顶层,不管z-index设置多少层都没有用。
解决方案:利用wx:if="{{isshowcav}}" 将canvas临时隐藏,要用到的时候再显示。不用再隐藏掉。
3.canvas里面的文字如何居中,官方文档虽然提供了案例,但是没有说具体是怎么用的。
解决方案:
const ctx = wx.createcanvascontext('mycanvas') ctx.setstrokestyle('red') ctx.moveto(150, 20) ctx.lineto(150, 170) ctx.stroke() ctx.setfontsize(15) ctx.settextalign('left') ctx.filltext('textalign=left', 150, 60) ctx.settextalign('center') ctx.filltext('textalign=center', 150, 80) ctx.settextalign('right') ctx.filltext('textalign=right', 150, 100) ctx.draw()
这里面的居中不是我们常用的css那种居中;而是忽略了文字宽高的意思,所以你还是要给文字设置一个(x,y)坐标,只要将这个坐标写上canvas宽度的一半,它就可以实现居中了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。