1.问题描述:
圆形的码图扫不出来。
解决方案:
微信小程序码,私有协议,只能微信扫。
2.问题描述:
监听扫描识别条码成功的回调,但是它仅会执行一次,识别成功会就再也不会进入该回调了,请问有什么办法可以连续识别条码?
解决方案:
在返回结果之前,已经释放了扫码资源。扫描到一个条码后,再扫描另外的条码并不能触发回调。
3.问题描述:
App调用scanBarcode.startScanForResult函数使用了扫码服务,扫描成功/失败都能触发callback回调函数,但是用户手动去点击扫码界面左上角的关闭按钮,无法触发callback回调函数。
解决方案:
可以尝试下在手势返回事件里面释放资源:
onBackPress() {
console.info('IndexComponent onBackPress');
}
4.问题描述:
App调用scanBarcode.startScanForResult函数使用了扫码服务,扫描成功/失败都能触发callback回调函数,但是用户手动去点击扫码界面左上角的关闭按钮,无法触发callback回调函数。
解决方案:
1、并不是只能通过photoViewPicker获取图片路径。 这个只是获取图片路径的一种方式。
2、比如也可以下载图片到沙箱,然后获取到图片的path, 最后通过fileUri.getUriFromPath(path)即可获取到图片的uri, 最后使用获取到的uri生成detectBarcode.InputImage对象, 最后通过detectBarcode.decode这个方法识别图像的二维码即可。
5.问题描述:
H5想要通过dsbridge调用原生扫码,原生扫码使用的是customScan,但是H5只会掉一次,customScan又是在另一个组件里,如何才能把customScan扫码后的值通过回调的方式传给H5?
解决方案:
基本思路:
1、H5调原生页面的方法(原生Web组件的页面),此方法实现跳转自定义扫码页面(customScan)
router.pushUrl({
url: "pages/customScanPage"
})
2、自定义扫码页面实现扫码,获取扫码结果后,返回Web组件的页面,这里需要传参(扫码结果)
router.back({
url: "pages/webPage",
params: {
originalValue: result[0].originalValue
}
})
3、Web组件的页面在onPageShow生命周期获取参数(扫码结果),调H5页面方法传递扫码结果
onPageShow() {
if (router.getParams()) {
let routerParams = router.getParams() as Record<string, string>
let originalValue: string = routerParams.originalValue;
this.controller.runJavaScript("getResult(\"" + originalValue + "\")")
}
}
4、H5页面定义方法(被原生WebPage页面调用)
function getResult(resultStr){
document.getElementById("demo").innerHTML = resultStr;
}</string,>
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。