高拍仪(PaperMaterialCamera)

# 打开高拍仪 openDevice

● 版本限制

3.2.2 +

● 接口说明
打开高拍仪并显示预览画面,  
接口提供了四种对接模式,参数mode分别对应以下值:

"js-video",(默认模式),适合https地址,本地localhost地址,
在政务浏览器时支持任意协议地址包括http,此模式会显示视频流的预览画面,
推荐办公模式及自助模式的场景使用;

"js-image",此模式通过画面帧的方式显示预览画面,不受场景和使用软件的影响,
适用范围最广,当使用"js-video"模式时可能会因为场景原因自动切换到"js-image"模式;

"window-origin",此模式通过一个无边框窗口内嵌第三方应用的模式,
适用于第三方应用内嵌高拍仪场景,更多适用于自助场景非BS架构的CS架构应用上;

"window-tools",此模式提供一个开箱即用的工具窗口,可以减少用户的开发对接量,
且提供的用户工具也更多,但是会和业务系统分离形成一定的割裂感;
● Typescript 类型参考
// 返回数据类型
type ResBody = {
    resultCode: number, resultMessage: string, data: string[]
}

// 'js-video' 模式的参数
type JsVideoModeBody = {
    documentId: string, // 预览窗口容器的id
    mode?: 'js-image',
    width?: number, // 高拍仪分辨率(宽)
    height?: number, // 高拍仪分辨率(高)
    performance?: 1 | 0.75 | 0.5, // 性能参数 1 效果最佳  0.75 均衡模式  0.5 性能最佳
    showCorpView?: boolean, // 是否显示纠偏裁剪框
}

// 'js-image' 模式的参数
type JsImageModeBody = JsVideoModeBody

// 'window-tools' 模式的参数
type WindowToolsModeBody = {
    dataType?: 'img'|'pdf',
    maxNum?:number
}

// 请求参数类型
type ReqBody = JsVideoModeBody | JsImageModeBody | WindowToolsModeBody

zwexplorer.PaperMaterialCamera.openDevice(
    data: ReqBody, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 参数说明
参数 类型 必填 说明
data Object 请求对象
data.documentId String 预览窗口容器的id,('js-image' 'js-video')
data.mode String 使用模式 'js-video'(默认)|'js-image'| 'window-tools'| 'window-origin'
data.width Number 高拍仪分辨率(宽),('js-image' 'js-video')
data.height Number 高拍仪分辨率(高),('js-image' 'js-video')
data.performance Number 性能参数 1 效果最佳 0.75 均衡模式 0.5 性能最佳 ,('js-image' 'js-video')
data.showCorpView Boolean 是否显示纠偏裁剪框 ,('js-image' 'js-video')
data.dataType String 值为'img' 或'pdf',返回的数据格式,默认为 'img' ('window-tools')
data.maxNum Number 每次调用接口最多能拍的图片保存张数,默认为无限张数 ('window-tools')
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Array | string 返回 img 的拍照模式时返回 string[],pdf 的拍照模式时返回 string
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.openDevice({}, (res) => {
  // 返回数据
});

# 高拍仪拍照(新) takePicture

● 版本限制

3.2.2 +

● 接口说明
高拍仪拍照, 拍照成功后返回图片数据
● Typescript 类型参考
// 返回数据类型
type ResBody = {
    resultCode: number, resultMessage: string, data: {} 
}

// 请求参数类型
type ReqBody = {
    autoCrop?: boolean, // 是否启用自动纠偏裁剪
}

zwexplorer.PaperMaterialCamera.takePicture(
    data?: {}, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 参数说明
参数 类型 必填 说明
data Object 请求对象
data.autoCrop Boolean 是否启用自动纠偏裁剪,true(默认)会返回纠偏裁剪后的图像,false会返回原始图像
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Object 接口返回的详细数据
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.takePicture({autoCrop: true},(res)=>{
  // 返回数据
})

# 关闭高拍仪 closeDevice

● 版本限制

3.2.2 +

● 接口说明
关闭高拍仪
● Typescript 类型参考
type ResBody = {
    resultCode: number, resultMessage: string, data: {} 
}

zwexplorer.PaperMaterialCamera.closeDevice(
    data?: {}, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Object 接口返回的详细数据
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.closeDevice({},(res)=>{
  // 返回数据
})

# 高拍仪拍照(旧) takePicture

● 接口说明
使用高拍仪拍照,返回 base64 图片信息或者 pdf 文件   
(3.2.2以上的版本依旧可用,但不推荐使用,推荐使用新接口)
● Typescript 类型参考
// 返回数据类型
type ResBody = {
    resultCode: number, resultMessage: string, data: []
}

// 请求参数类型
type ReqBody = {
    dataType?: 'img'|'pdf',
    maxNum?:number
    oneTake?:boolean,
    useSwitch?:boolean,
    useRotate?:boolean
}

zwexplorer.PaperMaterialCamera.takePicture(
    data: ReqBody, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 参数说明
参数 类型 必填 说明
data Object 请求对象
data.oneTake Boolean 是否拍一张照片直接返回并关闭,默认否
data.dataType String 值为'img' 或'pdf',返回的数据格式,默认为 img
data.maxNum Number 每次调用接口最多能拍的图片保存张数,默认为无限张数
data.useSwitch Boolean 是否打开切换摄像头按钮,默认否
data.useRotate Boolean 是否打开旋转按钮,默认否
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Array | string 返回 img 的拍照模式时返回 string[],pdf 的拍照模式时返回 string
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.takePicture({}, (res) => {
  // 返回数据
});

# 图像分析 pictureAnalysis

● 版本限制

3.0.6 +

● 接口说明
接口传入图片的base64数据,返回纠偏坐标及裁剪后的base64数据(不禁止裁剪时返回)
● Typescript 类型参考
// 返回数据类型
type ResBody = {
    resultCode: number, resultMessage: string, data: {
        coordinate: { 
            x1: number, 
            y1: number, 
            x2: number, 
            y2: number, 
            x3: number, 
            y3: number, 
            x4: number, 
            y4: number, 
            angle: number
        }, 
        targetBase64: string | ''
    }
}

// 请求参数类型
type ReqBody = {
    imgBase64: string,
    notUseCut?: boolean,
}

zwexplorer.PaperMaterialCamera.takePicture(
    data: ReqBody, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 参数说明
参数 类型 必填 说明
data Object 请求对象
data.imgBase64 String 需要解析的图像的base64数据
data.notUseCut Boolean 是否不使用裁剪,默认裁剪(true)
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Object 返回参数
res.data.coordinate Object 图像解析后的坐标参数
res.data.x1 Number x1坐标参数
res.data.x2 Number x2坐标参数
res.data.x3 Number x3坐标参数
res.data.x4 Number x4坐标参数
res.data.y1 Number y1坐标参数
res.data.y2 Number y2坐标参数
res.data.y3 Number y3坐标参数
res.data.y4 Number y4坐标参数
res.data.angle Number 偏转角(弧度角而并非角度值)
res.data.targetBase64 String 裁剪后的图像的base64数据
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.pictureAnalysis({
    imgBase64: '',
    notUseCut: false
}, (res) => {
  // 返回数据
});

# 获取默认摄像头信息 getUsedDeviceInfo

● 版本限制

3.0.6 +

● 接口说明
获取配置中默认高拍仪的设备label和推荐分辨率
● Typescript 类型参考
// 返回数据类型
type ResBody = {
    resultCode: number, resultMessage: string, data: {
        cameraLabel: strring, 
        resolution: {
            width: number,
            height: number
        }
    }
}

// 请求参数类型
type ReqBody = {}

zwexplorer.PaperMaterialCamera.takePicture(
    data: ReqBody, 
    callback?: (res: ResBody)=>void
): Promise<ResBody>
● 返回数据
参数 类型 必然存在 说明
res.resultCode Number 状态码,0 为正常,其它为异常 [状态码参考]
res.data Object 返回参数
res.data.cameraLabel String 高拍仪摄像头的设备label
res.data.resolution Object 高拍仪摄像头的推荐分辨率
res.data.resolution.width Number 分辨率(宽)
res.data.resolution.height Number 分辨率(高)
res.resultMessage String 接口消息
● 接口示例
zwexplorer.PaperMaterialCamera.getUsedDeviceInfo({}, (res) => {
  // 返回数据
});