小程序图片长按识别功能的实现方法

背景

今天,做的小程序项目要求,个人中心的客服图片用户长按时可以识别其二维码

百度无果,参考小程序官方文档后,发现:

1.文档中有一句提示

"image组件中二维码/小程序图片不支持长按识别,仅在 wx.previewImage 中支持长按识别"

2.即便实现了 “wx.previewImage” 效果,但依旧是不支持二维码识别的

附录文档位置:nofollow" target="_blank" href="https://developers.weixin.qq.com/miniprogram/dev/component/image.html?search-key=%E9%95%BF%E6%8C%89">小程序图片长按识别

代码设计

在这也是一个不错的知识点,在此进行一番实现流程的记录,欢迎指摘.

①. wxml 页面元素设计

作为引导界面,只需放置一张图片即可,以我的代码为例

rush:xml;"> //# 使用简单的实现方式,直接赋值一个图片链接得了 etow.com/Public/Index/images/shewm.jpg" mode="widthFix" src="https://img.fetow.com/Public/Index/images/shewm.jpg" bindtap="previewImage">

②. js 文件实现 “previewImage”方法

在对应的 js 文件中,添加了如下的方法

rush: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 上

rush:js;"> //下载图片 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里面的文字如何居中,官方文档虽然提供了案例,但是没有说具体是怎么用的。

解决方案:

rush:js;"> 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',80)

ctx.setTextAlign('right')
ctx.fillText('textAlign=right',100)

ctx.draw()

这里面的居中不是我们常用的css那种居中;而是忽略了文字宽高的意思,所以你还是要给文字设置一个(x,y)坐标,只要将这个坐标写上canvas宽度的一半,它就可以实现居中了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...