主题
获取OCR模型信息 - OcrGetModelInfo
函数简介
查询指定 OCR 模型的元数据、生命周期状态、Runtime 快照及热身/激活诊断信息。
接口名称
OcrGetModelInfoDLL 调用
long OcrGetModelInfo(long ola, long modelHandle);参数说明
| 参数名 | 类型 | 说明 |
|---|---|---|
| ola | 长整数型 | OLAPlug 对象指针,由 CreateCOLAPlugInterFace 生成。 |
| modelHandle | 长整数型 | 模型句柄;内置 mobile 为 0;自定义模型为 OcrLoadModel / OcrLoadModelMemory 返回值 |
示例
SDK 调用
cpp
#include "OLAPlugServer.h"
OLAPlugServer ola;
auto result = ola.OcrGetModelInfo(0);csharp
using OLAPlug;
var ola = new OLAPlugServer();
var result = ola.OcrGetModelInfo(0);python
from OLAPlugServer import OLAPlugServer
ola = OLAPlugServer()
result = ola.OcrGetModelInfo(0)java
import com.olaplug.OLAPlugServer;
OLAPlugServer ola = new OLAPlugServer();
var result = ola.OcrGetModelInfo(0);cpp
var ola = com("OlaPlug.OlaSoft")
var result = ola.OcrGetModelInfo(0)vbscript
Set ola = CreateObject("OlaPlug.OlaSoft")
result = ola.OcrGetModelInfo(0)text
.局部变量 ola, OLAPlug
ola.创建 ()
result = ola.OcrGetModelInfo(0)aardio
import OLAPlugServer;
var ola = OLAPlugServer();
var result = ola.OcrGetModelInfo(0);text
变量 ola <类型 = OLAPlugServer>
ola = 新建 OLAPlugServer
自动 result = ola.OcrGetModelInfo(0)cpp
#include "OLAPlugServer.h"
OLAPlugServer ola;
auto result = ola.OcrGetModelInfo(0);原生 DLL 调用
cpp
long instance = CreateCOLAPlugInterFace();
long ptr = OcrGetModelInfo(instance, 0);
if (ptr != 0) {
char buffer[512] = {0};
GetStringFromPtr(ptr, buffer, sizeof(buffer));
FreeStringPtr(ptr);
}csharp
using System.Runtime.InteropServices;
using System.Text;
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern long CreateCOLAPlugInterFace();
[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 OcrGetModelInfo(long ola, long modelHandle);
long instance = CreateCOLAPlugInterFace();
long ptr = OcrGetModelInfo(instance, 0);
if (ptr != 0) {
StringBuilder sb = new StringBuilder(GetStringSize(ptr) + 1);
GetStringFromPtr(ptr, sb, sb.Capacity);
FreeStringPtr(ptr);
string result = sb.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()
ptr = ola.OcrGetModelInfo(instance, 0)
if ptr:
buf = create_string_buffer(512)
ola.GetStringFromPtr(ptr, buf, 512)
ola.FreeStringPtr(ptr)
result = buf.value.decode("utf-8")返回值
长整数型:PascalCase JSON 字符串指针。
成功时含 ModelHandle、State、Active、Loaded、BackendId、Runtime、Warmup、Activation 等;失败时 {"Success":false,"ModelHandle":...,"Error":"..."}。
注意事项
- 需要插件已开通 OCR 模块权限(Reg、Login 的 FeatureList 中包含 OCR 特性)。
- 字段说明见 OCRModelInfo与ModelConfig说明。
- 不含 password、模型包路径等加载期敏感信息;不含 完整可写推理调参(见 OcrGetModelConfig)。
- 执行
OcrWarmupModel后,可通过本接口或 OcrListModels 读取Warmup统计。 - 返回的 JSON 字符串须调用 FreeStringPtr 释放。
