OCR识别
tip
- OCR模块是属于对图像进行识别
- OCR模块的对象前缀是ocr,例如 ocr.initOcr()这样调用
- 目前的OCR包含了 appleVision
- 3.18.0+ 新增了ocrMut作为多实例模式的ocr前缀
- 5.12.0 新增了paddleLiteOcr
- 5.21.0 新增了paddleNcnnOcrV5
单实例模式
ocr.initOcr 初始化
- 初始化OCR模块
- @param map map参数表
- key分别为:
- type : OCR类型,值分别为 appleVision = ios自带的Vision模块
- 如果类型是 appleVision, 参数设置为 :
{"type":"appleVision","level":"fast","languages":"zh-Hans,en-US"}
- level: fast,代表快速的,accurate:代表精准的
- languages: 识别的语言,默认是zh-Hans,en-US中文简体和英文,
- 支持的有
["en-US", "fr-FR", "it-IT", "de-DE", "es-ES", "pt-BR", "zh-Hans", "zh-Hant"]
- @return
{bool}布尔型 成功或者失败
- appleVision OCR例子
function main() {
let appleVision = {"type": "appleVision", "level": "accurate", "languages": "zh-Hans,en-US"}
let inited = ocr.initOcr(appleVision)
logd("初始化结果 -" + inited);
if (!inited) {
loge("error : " + ocr.getErrorMsg());
return;
}
for (var ix = 0; ix < 20; ix++) {
//读取一个bitmap
let img = image.captureFullScreen();
if (img == null || img == undefined || img.uuid == null || img.uuid == undefined || img.uuid == "") {
loge("读取图片失败");
continue;
}
console.time("1")
logd("start---ocr");
// 对图片进行识别
let result = ocr.ocrImage(img, 20 * 1000, {});
logd(result)
if (result) {
logd("ocr结果-》 " + JSON.stringify(result));
for (var i = 0; i < result.length; i++) {
var value = result[i];
logd("文字 : " + value.label + " x: " + value.x + " y: " + value.y + " width: " + value.width + " height: " + value.height);
}
} else {
logw("未识别到结果");
}
logd("耗时: " + console.timeEnd(1) + " ms")
image.recycle(img)
sleep(1000);
logd("ix = " + ix)
}
//释放所有资源
ocr.releaseAll();
}
main();
ocr.ocrImage 识别文字
- 对 AutoImage 进行OCR,返回的是JSON数据,其中数据类似于与:
[
{
"label": "奇趣装扮三阶盘化",
"confidence": 0.48334712,
"x": 11,
"y": 25,
"width": 100,
"height": 100
}
]
- label: 代表是识别的文字
- confidence:代表识别的准确度
- x: 代表X开始坐标
- Y: 代表Y开始坐标
- width: 代表宽度
- height: 代表高度
- @param bitmap 图片
- @param timeout 超时时间 单位毫秒
- @param extra 扩展参数,map形式,例如
{"token":"xxx"} - @return
{JSON}JSON对象
代码例子常见
OCR初始化
ocr.getErrorMsg 获取错误消息
- 获取OCR错误消息
- @return
{string}null代表没有错误
代码例子常见
OCR初始化
ocr.releaseAll 释放OCR资源
- 释放OCR占用的资源
- @return
{bool}成功或者失败
代码例子常见
OCR初始化
多实例模式
ocrMut.releaseAll 释放所有
- EC 脱机 5.17.0+
// 见代码例子
ocrMut.initOcr 初始化
-
初始化OCR模块
-
@param map map参数表
-
key分别为:
-
type : OCR类型,值分别为 appleVision = ios自带的Vision模块 tess = TesseractOcr, ocrLite=ncnn神经网络的ocrLite , paddleOcrOnline = EC自带的PC端的paddleOcr服务程序,paddleLiteOcr = paddleLite,paddleNcnnOcrV5=ncnn版本的paddleocr,paddleOnnxOcr = onnxruntime的ppocr-v5的模型实现
-
如果类型是 appleVision, 参数设置为 :
{"type":"appleVision","level":"fast","languages":"zh-Hans,en-US"}- level: fast,代表快速的,accurate:代表精准的
- languages: 识别的语言,默认是zh-Hans,en-US中文简体和英文,
- 支持的有
["en-US", "fr-FR", "it-IT", "de-DE", "es-ES", "pt-BR", "zh-Hans", "zh-Hant"]
paddleLiteOcr = paddleLite,paddleOnnxOcr = onnxrntime的ppocr-v5的模型实现,
- level: fast,代表快速的,accurate:代表精准的
-
如果类型是
paddleLiteOcr, paddleLiteOcr = paddleLite,paddleOnnxOcr = onnxrntime的ppocr-v5的模型实现,- 注意 5.16+由于onnxruntime和paddlelite冲突,使用onnx重写了paddlelite底层实现,
- 如果是 paddleLiteOcr或者paddleOnnxOcr,参数如下
{"type":"paddleLiteOcr","cpuThreadNum":2} - cpuThreadNum 使用的CPU线程数,如果不知道 不写即可,-1 代表全部cpu数量,-2 代表cpu数量的一半,识别速度可以用这个值调整
- modelPath: 模型路径,如果是外部路径例如 /sdcard/models/代表是sdcard下面的,默认自带有模型 不写这一项即可
- labelPath: 训练的文字标签文件路径,可以是外部的 例如 /sdcard/labels/ppocr_keys_v1.txt,默认自带有模型 不写这一项即可
- detModelFilename: 检测模型文件名,onnx 结尾的文件名称,放到 modelPath 参数的路径下,默认自带有模型 不写这一项即可
- recModelFilename: 识别模型文件名,onnx 结尾的文件名称,放到 modelPath 参数的路径下,默认自带有模型 不写这一项即可
- clsModelFilename: 分类模型文件名,onnx 结尾的文件名称,放到 modelPath 参数的路径下,默认自带有模型 不写这一项即可
- padding 图像外接白框,用于提升识别率,文字框没有正确框住所有文字时,增加此值。默认 10。识别速度可以用这个值调整
- boxThresh 图像中文字部分和背景部分分割阈值。值越大,文字部分会越小。取值范围:[0, 1],默认值为0.3。
- boxScoreThresh 文本检测所得框是否保留的阈值,值越大,召回率越低。取值范围:[0, 1],默认值为0.5。
- unClipRatio 控制文本检测框的大小,值越大,检测框整体越大。取值范围:[1.6, 2.0],默认值为 1.6。
- doAngle 1启用(1)/禁用(0) 文字方向检测,只有图片倒置的情况下(旋转90~270度的图片),才需要启用文字方向检测,默认1
- mostAngle 启用(1)/禁用(0) 角度投票(整张图片以最大可能文字方向来识别),当禁用文字方向检测时,此项也不起作用,默认1
- maxSideLen 如果输入图像的最大边大于max_side_len,则会按宽高比,将最大边缩放到max_side_len。默认为 960,识别速度可以用这个值调整
-
如果类型是 paddleNcnnOcrV5,参数设置如下
- numThread: 线程数量,-1 等于全部,-2 等于设备CPU的一半,0代表不设置,识别速度可以用这个值调整
- modelsDir: 模型的路径文件路径。默认不写就使用自带的
- padding: 图像外接白框,用于提升识别率,文字框没有正确框住所有文字时,增加此值。默认 32,识别速度可以用这个值调整
- maxSideLen 如果输入图像的最大边大于max_side_len,则会按宽高比,将最大边缩放到max_side_len。默认为 640,识别速度可以用这个值调整
- keysName: 训练的文字标签文件名称,可以是外部的 例如 keys.txt,默认自带有模型 不写这一项即可
- detName: 检测模型文件名,param 结尾的文件名称,放到 modelsDir 参数的路径下,名字叫det.param就写det,不用带param后缀,默认自带有模型 不写这一项即可
- recName: 识别模型文件名,onnx 结尾的文件名称,放到 modelsDir 参数的路径下,名字叫rec.param就写det,不用带param后缀,默认自带有模型 不写这一项即可