Skip to content

指定bmp图片详细信息 - OcrFromBmpDataDetails

函数简介

对指定bmp格式图片进行文字识别并返回详细信息。

接口名称

OcrFromBmpDataDetails

DLL调用

long OcrFromBmpDataDetails(long ola, long imgPtr, int size);

参数说明

参数名类型说明
ola长整数型OLAPlug对象的指针,由 CreateCOLAPlugInterFace 接口生成。
imgPtr长整数型bmp图片数据流地址。
size整数型图片大小。

示例

SDK 调用

cpp
#include "OLAPlugServer.h"

OLAPlugServer ola;
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
auto detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize);
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
csharp
using OLAPlug;

var ola = new OLAPlugServer();
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
var detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize);
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
python
from OLAPlugServer import OLAPlugServer

ola = OLAPlugServer()
# bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
bmpPtr = bmpData
bmpSize = 102400
detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize)
# detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
# 各字段说明见 OcrDetails 返回值文档
java
import com.olaplug.OLAPlugServer;

OLAPlugServer ola = new OLAPlugServer();
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
var detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize);
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
cpp
var ola = com("OlaPlug.OlaSoft")
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
var bmpPtr = bmpData
var bmpSize = 102400
var detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize)
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
vbscript
Set ola = CreateObject("OlaPlug.OlaSoft")
' bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
bmpPtr = bmpData
bmpSize = 102400
detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize)
' detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
' 各字段说明见 OcrDetails 返回值文档
text
.局部变量 ola, OLAPlug
ola.创建 ()
' bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
bmpPtr = bmpData
bmpSize = 102400
detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize)
' detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
' 各字段说明见 OcrDetails 返回值文档
aardio
import OLAPlugServer;
var ola = OLAPlugServer();
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
var bmpPtr = bmpData;
var bmpSize = 102400;
var detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize);
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
text
变量 ola <类型 = OLAPlugServer>
ola = 新建 OLAPlugServer
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
长整数 bmpPtr = bmpData
整数 bmpSize = 102400
自动 detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize)
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档
cpp
#include "OLAPlugServer.h"

OLAPlugServer ola;
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
auto detail = ola.OcrFromBmpDataDetails(bmpPtr, bmpSize);
// detail.Regions 为识别框列表,detail.Text 为合并后的识别文本
// 各字段说明见 OcrDetails 返回值文档

原生 DLL 调用

cpp
long instance = CreateCOLAPlugInterFace();
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
long detailJsonPtr = OcrFromBmpDataDetails(instance, bmpPtr, bmpSize);
if (detailJsonPtr != 0) {
    char detailJson[512] = {0};
    GetStringFromPtr(detailJsonPtr, detailJson, sizeof(detailJson));
    FreeStringPtr(detailJsonPtr);
}
csharp
using System.Runtime.InteropServices;
using System.Text;

[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int GetStringFromPtr(long ptr, StringBuilder lpString, int size);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int FreeStringPtr(long ptr);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int GetStringSize(long ptr);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern long CreateCOLAPlugInterFace();

long instance = CreateCOLAPlugInterFace();
// bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
long bmpPtr = bmpData;
int bmpSize = 102400;
long detailJsonPtr = OcrFromBmpDataDetails(instance, bmpPtr, bmpSize);
if (detailJsonPtr != 0) {
    StringBuilder detailJson = new StringBuilder(GetStringSize(detailJsonPtr) + 1);
    GetStringFromPtr(detailJsonPtr, detailJson, detailJson.Capacity);
    FreeStringPtr(detailJsonPtr);
    string detailJsonStr = detailJson.ToString();
}
python
from ctypes import CDLL, c_int, c_int64, create_string_buffer

ola = CDLL("OLAPlug_x64.dll")
ola.CreateCOLAPlugInterFace.restype = c_int64
instance = ola.CreateCOLAPlugInterFace()
# bmpPtr/bmpSize 为 BMP 字节流地址与长度(可由文件读入内存获得)
bmpPtr = bmpData
bmpSize = 102400
detailJsonPtr = OcrFromBmpDataDetails(instance, bmpPtr, bmpSize)
if detailJsonPtr:
    buf = create_string_buffer(512)
    ola.GetStringFromPtr(detailJsonPtr, buf, 512)
    ola.FreeStringPtr(detailJsonPtr)
    detailJson = buf.value.decode("utf-8")

返回值

返回值说明
(返回值)字符串指针地址,返回识别到的JSON字符串,如:。
json
{
    "Regions": [
        {
            "Score": 0,
            "Text": "bbbbbb",
            "Center": { "x": 100, "y": 200 },
            "Vertices": [
                { "x": 75, "y": 190 },
                { "x": 125, "y": 190 },
                { "x": 125, "y": 210 },
                { "x": 75, "y": 210 }
            ],
            "Angle": 0
        }
    ],
    "Text": "bbbbbb"
}
字段名类型说明
Regions数组Regions 结果列表,详见下方字段说明。
Text字符串识别文本。

Regions 元素字段说明:

字段名类型说明
Score整数识别置信度分值。
Text字符串识别文本。
Center对象中心点坐标对象。
Vertices数组顶点坐标集合。
Angle整数角度值。

Regions[].Center 字段说明:

字段名类型说明
x整数X 坐标。
y整数Y 坐标。

Regions[].Vertices 元素字段说明:

字段名类型说明
x整数X 坐标。
y整数Y 坐标。
  • Regions:所有识别到的数据集
  • Score:识别评分,分值越高越准确
  • Center:识别结果中心点
  • Vertices:识别结果的4个顶点
  • Angle:识别结果角度

返回的字符串指针需调用 FreeStringPtr 释放内存。

注意事项

项目说明
字体比较特殊或者背景复杂识别不准确的字体比较特殊或者背景复杂识别不准确的,建议用图像识别来处理。