OcrResultUtils.cpp 4.16 KB
Newer Older
yangql's avatar
yangql committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#ifdef __JNI__
#include <OcrUtils.h>
#include "OcrResultUtils.h"

OcrResultUtils::OcrResultUtils(JNIEnv *env, OcrResult &ocrResult) {
    jniEnv = env;

    jclass jOcrResultClass = env->FindClass("com/benjaminwan/ocrlibrary/OcrResult");

    if (jOcrResultClass == NULL) {
        printf("OcrResult class is null\n");
    }

    jmethodID jOcrResultConstructor = env->GetMethodID(jOcrResultClass, "<init>",
                                                       "(DLjava/util/ArrayList;DLjava/lang/String;)V");

    jobject textBlocks = getTextBlocks(ocrResult.textBlocks);
    jdouble dbNetTime = (jdouble) ocrResult.dbNetTime;
    jdouble detectTime = (jdouble) ocrResult.detectTime;
    jstring jStrRest = jniEnv->NewStringUTF(ocrResult.strRes.c_str());

    jOcrResult = env->NewObject(jOcrResultClass, jOcrResultConstructor, dbNetTime,
                                textBlocks, detectTime, jStrRest);
}

OcrResultUtils::~OcrResultUtils() {
    jniEnv = NULL;
}

jobject OcrResultUtils::getJObject() {
    return jOcrResult;
}

jclass OcrResultUtils::newJListClass() {
    jclass clazz = jniEnv->FindClass("java/util/ArrayList");
    if (clazz == NULL) {
        printf("ArrayList class is null\n");
        return NULL;
    }
    return clazz;
}

jmethodID OcrResultUtils::getListConstructor(jclass clazz) {
    jmethodID constructor = jniEnv->GetMethodID(clazz, "<init>", "()V");
    return constructor;
}

jobject OcrResultUtils::newJPoint(cv::Point &point) {
    jclass clazz = jniEnv->FindClass("com/benjaminwan/ocrlibrary/Point");
    if (clazz == NULL) {
        printf("Point class is null\n");
        return NULL;
    }
    jmethodID constructor = jniEnv->GetMethodID(clazz, "<init>", "(II)V");
    jobject obj = jniEnv->NewObject(clazz, constructor, point.x, point.y);
    return obj;
}

jobject OcrResultUtils::newJBoxPoint(std::vector<cv::Point> &boxPoint) {
    jclass jListClass = newJListClass();
    jmethodID jListConstructor = getListConstructor(jListClass);
    jobject jList = jniEnv->NewObject(jListClass, jListConstructor);
    jmethodID jListAdd = jniEnv->GetMethodID(jListClass, "add", "(Ljava/lang/Object;)Z");

    for (auto point : boxPoint) {
        jobject jPoint = newJPoint(point);
        jniEnv->CallBooleanMethod(jList, jListAdd, jPoint);
    }
    return jList;
}

jobject OcrResultUtils::getTextBlock(TextBlock &textBlock) {
    jobject jBoxPint = newJBoxPoint(textBlock.boxPoint);
    jfloat jBoxScore = (jfloat) textBlock.boxScore;
    jfloat jAngleScore = (jfloat) textBlock.angleScore;
    jdouble jAngleTime = (jdouble) textBlock.angleTime;
    jstring jText = jniEnv->NewStringUTF(textBlock.text.c_str());
    jobject jCharScores = newJScoreArray(textBlock.charScores);
    jdouble jCrnnTime = (jdouble) textBlock.crnnTime;
    jdouble jBlockTime = (jdouble) textBlock.blockTime;
    jclass clazz = jniEnv->FindClass("com/benjaminwan/ocrlibrary/TextBlock");
    if (clazz == NULL) {
        printf("TextBlock class is null\n");
        return NULL;
    }
    jmethodID constructor = jniEnv->GetMethodID(clazz, "<init>",
                                                "(Ljava/util/ArrayList;FIFDLjava/lang/String;[FDD)V");
    jobject obj = jniEnv->NewObject(clazz, constructor, jBoxPint, jBoxScore, textBlock.angleIndex,
                                    jAngleScore, jAngleTime, jText, jCharScores, jCrnnTime,
                                    jBlockTime);
    return obj;
}

jobject OcrResultUtils::getTextBlocks(std::vector<TextBlock> &textBlocks) {
    jclass jListClass = newJListClass();
    jmethodID jListConstructor = getListConstructor(jListClass);
    jobject jList = jniEnv->NewObject(jListClass, jListConstructor);
    jmethodID jListAdd = jniEnv->GetMethodID(jListClass, "add", "(Ljava/lang/Object;)Z");

    for (int i = 0; i < textBlocks.size(); ++i) {
        auto textBlock = textBlocks[i];
        jobject jTextBlock = getTextBlock(textBlock);
        jniEnv->CallBooleanMethod(jList, jListAdd, jTextBlock);
    }
    return jList;
}

jfloatArray OcrResultUtils::newJScoreArray(std::vector<float> &scores) {
    jfloatArray jScores = jniEnv->NewFloatArray(scores.size());
    jniEnv->SetFloatArrayRegion(jScores, 0, scores.size(), (jfloat *) scores.data());
    return jScores;
}

#endif