为帮助用户更好更快的使用原生插件,论坛维护了一个示例,示例中包含示例代码、知识点讲解、注意事项等,供您参考。
FNScanner 原生插件是一个二维码/条形码扫描器,是 scanner 原生插件的优化升级版。在 iOS 平台上本原生插件底层集成了系统自带扫码功能。
注意:使用本原生插件前,需在云编译页面勾选添加访问摄像头权限,若要访问相册也需沟通申请访问相册权限 不能同时使用的原生插件:wwprint
本原生插件封装了两套扫码方案:
方案一
开发者通过调用 openScanner 接口直接打开自带默认 UI 效果的二维码/条形码扫描页面,本界面相当于打开一个 window 窗口,其界面内容不支持自定义。用户可在此界面实现功能如下:
打开关闭闪关灯
从系统相册选取二维码/条码图片进行解密操作
打开摄像头,自动对焦扫码想要解析的二维码/条码
方案二
通过 openView 接口打开一个自定义大小的扫描区域(本区域相当于打开一个 frame)进行扫描。开发者可自行 open 一个 frame 贴在原生插件上,从而实现自定义扫描界面的功能。然后配合使用 setFrame、closeView、switchLight 等接口实现开关闪光灯、重设扫描界面位置大小、图片解码、字符串编码等相关功能。详情请参考原生插件接口参数。
注意:iOS 1.2.1版本以后不再支持条形码图片解析
注意:
在android 平台上,打开扫码原生插件后app切入后台再次回到前台时,扫码界面会有黑屏问题,需要开发者调用onPause、onResume接口自行处理,参考接口详情。
打开自带默认 UI 效果的二维码/条形码扫描页面,本界面相当于打开一个 window 窗口,其界面内容不支持自定义
open({params}, callback(ret))
sound:
autorotation:
saveToAlbum:
verticalLineColor:
landscapeLineColor:
hintText:
albumText:
lightText:
closeText:
isAlbum:
isLight:
isPush:
font:
{
hintText:{
size:16, //数字类型,二维码/条形码界面扫码界面底下的文字大小
color: '', //字符串类型;二维码/条形码界面扫码界面底下的文字颜色,支持#、rgb、rgba;默认:#FFFFFF
},
albumText:{
size:16, //数字类型,相册按钮文字大小
color: '', //字符串类型;相册按钮文字颜色,支持#、rgb、rgba;默认:#FFFFFF
},
lightText:{
size:16, //数字类型,灯光开启/关闭文字大小
color: '', //字符串类型;灯光开启/关闭文字颜色,支持#、rgb、rgba;默认:#FFFFFF
}
}
saveImg:
{
path: 'fs://a.jpg', //字符串类型;保存的文件路径;若路径不存在,则创建此路径,只支持fs://协议
w: 200, //(可选项)数字类型;生成图片的宽度,默认:200
h: 200 //(可选项)数字类型;生成图片的高度,默认:200
}
isDrawQRCodeRect:
qRCodeRectWidth:
qRCodeRectColor:
isGBK:
encoding:
isEdit:
cameraDirection:
ret:
{
eventType: 'cancel', //字符串类型;扫码事件类型
//取值范围:
//show(原生插件显示)
//cameraError(访问摄像头失败)
//albumError(访问相册失败)
//cancel(用户取消扫码)
//selectImage(用户从系统相册选取二维码图片)
//cancelImage(用户取消从系统相册选取二维码图片,仅支持iOS)
//success(识别二维码/条码图片成功)
//fail(扫码失败)
imgPath: '', //字符串类型;需要保存的二维码图片绝对路径(自定义路径)
albumPath: '', //字符串类型;需要保存的二维码图片绝对路径(相册路径)
content: '' //扫描的二维码/条形码信息
}
var FNScanner = api.require('FNScanner');
FNScanner.open({
autorotation: true
}, function(ret, err) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
打开二维码/条码扫描器
openScanner({params}, callback(ret))
sound:
autorotation:
saveToAlbum:
verticalLineColor:
saveImg:
{
path: 'fs://a.jpg', //字符串类型;保存的文件路径;若路径不存在,则创建此路径,只支持fs://协议
w: 200, //(可选项)数字类型;生成图片的宽度,默认:200
h: 200 //(可选项)数字类型;生成图片的高度,默认:200
}
hintText:
font:
{
hintText:{
size:16, //数字类型,二维码/条形码界面扫码界面底下的文字大小
color: '', //字符串类型;二维码/条形码界面扫码界面底下的文字颜色,支持#、rgb、rgba;默认:#FFFFFF
}
}
isAlbum:
isPush:
isDrawQRCodeRect:
qRCodeRectWidth:
qRCodeRectColor:
isLight:
isGBK:
encoding:
cameraDirection:
ret:
{
eventType: 'cancel', //字符串类型;扫码事件类型
//取值范围:
//show(原生插件显示)
//cameraError(访问摄像头失败)
//albumError(访问相册失败)
//cancel(用户取消扫码)
//selectImage(用户从系统相册选取二维码图片)
//success(识别二维码/条码图片成功)
//fail(扫码失败)
imgPath: '', //字符串类型;需要保存的二维码图片绝对路径(自定义路径)
albumPath: '', //字符串类型;需要保存的二维码图片绝对路径(相册路径)
content: '' //扫描的二维码/条形码信息
}
var FNScanner = api.require('FNScanner');
FNScanner.openScanner({
autorotation: true
}, function(ret) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
打开可自定义的二维码/条形码扫描器 【注】:该接口需要在apiready中做生命周期处理,详情见接口onpause,onresume
openView({params}, callback(ret))
rect:
{
x: 0, //(可选项)数字类型;原生插件左上角的 x 坐标(相对于所属的 Window 或 Frame);默认:0
y: 0, //(可选项)数字类型;原生插件左上角的 y 坐标(相对于所属的 Window 或 Frame);默认:0
w: 320, //(可选项)数字类型;原生插件的宽度;支持设置'auto';默认:所属的 Window 或 Frame 的宽度
h: 480 //(可选项)数字类型;原生插件的高度;支持设置'auto';默认:所属的 Window 或 Frame 的高度
}
rectOfInterest:
{
x: 0, //(可选项)数字类型;扫码识别区域左上角的 x 坐标(相对于扫码区rect);默认:0
y: 0, //(可选项)数字类型;扫码识别区域左上角的 y 坐标(相对于扫码区rect);默认:0
w: 320, //(可选项)数字类型;扫码识别区域的宽度;默认:扫码区rect的宽度
h: 480 //(可选项)数字类型;扫码识别区域的高度;默认:扫码区rect的高度
}
sound:
autorotation:
saveToAlbum:
saveImg:
{
path: 'fs://a.jpg', //字符串类型;保存的文件路径;若路径不存在,则创建此路径,只支持 fs:// 协议
w: 200, //(可选项)数字类型;生成图片的宽度,默认:200
h: 200 //(可选项)数字类型;生成图片的高度,默认:200
}
interval:
isDrawQRCodeRect:
qRCodeRectWidth:
qRCodeRectColor:
isGBK:
encoding:
cameraDirection:
fixedOn:
fixed:
ret:
{
eventType: 'success', //字符串类型;扫码事件类型
//取值范围:
//show(原生插件显示)
//cameraError(访问摄像头失败)
//albumError(访问相册失败)
//success(扫码成功)
//fail(扫码失败)
imgPath: '', //字符串类型;需要保存的二维码图片绝对路径(自定义路径)
albumPath: '', //字符串类型;需要保存的二维码图片绝对路径(相册路径)
content: '' //扫描的二维码/条形码信息
}
var FNScanner = api.require('FNScanner');
FNScanner.openView({
autorotation: true
}, function(ret) {
if (ret) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
通知当前本原生插件app进入回到前台。此时原生插件会进行一些资源的恢复操作,防止照相机回来之后黑屏
【注】:该方法需要在apiready中调用
onResume()
apiready = function() {
var FNScanner = api.require('FNScanner');
api.addEventListener({
name:'resume'
}, function(ret, err){
FNScanner.onResume();
alert('应用回到前台');
});
}
iOS系统,Android系统
可提供的1.0.0及更高版本
通知当前本原生插件app进入后台。此时原生插件会进行一些资源的暂停存储操作,防止照相机回来之后黑屏
【注】:该方法需要在apiready中调用
onPause()
apiready = function() {
var FNScanner = api.require('FNScanner');
api.addEventListener({
name:'pause'
}, function(ret, err){
FNScanner.onPause();
alert('应用进入后台');
});
}
iOS系统,Android系统
可提供的1.0.0及更高版本
重设可自定义的二维码/条形码扫描器的大小和位置
setFrame({params})
x:
y:
w:
h:
var FNScanner = api.require('FNScanner');
FNScanner.setFrame({
x: 10,
y: 64,
w: 300,
h: 300
});
iOS系统,Android系统
可提供的1.0.0及更高版本
关闭自定义大小的二维码/条码扫描器
closeView()
var FNScanner = api.require('FNScanner');
FNScanner.closeView();
iOS系统,Android系统
可提供的1.0.0及更高版本
二维码/条形码图片解码
decodeImg({params}, callback(ret, err))
sound:
path:
ret:
{
status: true, //布尔型;是否解码成功
content: '' //扫描的二维码/条形码信息
albumPath:'', //字符串类型;选择系统相册路径(path不传时返回)
}
err:
{
code: 1, //数字类型;错误码
//1:cameraError(访问摄像头失败)
//2:albumError(访问相册失败)
//3:图片识别失败,请检查图片是否正确
//-100:图片识别失败,编码格式不支持
}
var FNScanner = api.require('FNScanner');
FNScanner.decodeImg({
path: 'widget://res/img/yonbuilder.png'
}, function(ret, err) {
if (ret.status) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
将字符串生成二维码/条形码图片
encodeImg({params}, callback(ret))
type:
content:
saveToAlbum:
saveImg:
{
path: 'fs://a.jpg', //字符串类型;保存的文件路径;若路径不存在,则创建此路径,只支持fs://协议
w: 200, //(可选项)数字类型;生成图片的宽度,默认:200
h: 200 //(可选项)数字类型;生成图片的高度,默认:200
}
ret:
{
status: true, //布尔型;是否生成成功
imgPath: '', //字符串类型;需要保存的二维码图片绝对路径(自定义路径)
albumPath: '', //字符串类型;需要保存的二维码图片绝对路径(相册路径)
}
err:
{
code: 2, //数字类型;错误码
//2:albumError(访问相册失败)
}
var FNScanner = api.require('FNScanner');
FNScanner.encodeImg({
content: 'http://www.yonbuilder.com/',
saveToAlbum: true,
saveImg: {
path: 'fs://album.png',
w: 200,
h: 200
}
}, function(ret, err) {
if (ret.status) {
api.alert({
msg: JSON.stringify(ret)
})
} else {
api.alert({
msg: JSON.stringify(err)
})
}
});
iOS系统,Android系统
可提供的1.0.0及更高版本
打开/关闭闪光灯(在Android上,已打开扫码视图时有效)
switchLight({params})
status:
var FNScanner = api.require('FNScanner');
FNScanner.switchLight({
status: 'on'
});
iOS系统,Android系统
可提供的1.0.0及更高版本