opencv 手写选择题阅卷 (四)Android端 手机应用开发

来源:互联网 发布:类似蝰蛇音效的软件 编辑:程序博客网 时间:2024/04/30 09:40

opencv 手写选择题阅卷 (四)Android 手机应用开发

在PC端把代码调通以后开始开发Android 手机应用,因为主要功能代码为C++代码,所以需要通过NDK编译,JAVA通过JNI方式调用C++代码,好在opencv已经把android 下的库都编译好了,只需要连接就可以了,Android.mk文件内容如下:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

#OPENCV_CAMERA_MODULES:=off
OPENCV_INSTALL_MODULES:=off
OPENCV_LIB_TYPE:=STATIC


include H:\OpenCV-android-sdk\sdk\native\jni/OpenCV.mk

LOCAL_SRC_FILES := \
libWriterOCR.cpp \
H:\libWriterOCR\src\img_proc.cpp \
H:\libWriterOCR\src\recognition.cpp \
H:\libWriterOCR\src\table_proc.cpp \

LOCAL_C_INCLUDES += H:\libWriterOCR\include

LOCAL_LDLIBS += -llog -ldl -lm -landroid

LOCAL_MODULE := WriterOCR

include $(BUILD_SHARED_LIBRARY)

JNI接口中,输入图像数据数组和宽高,返回最终识别结果的 byte数组,主要代码如下:

extern "C" JNIEXPORT jbyteArray JNICALL Java_com_veryjuly_scl_writerscore_WriterOCR_doOCR(JNIEnv * env, jobject jobj, jbyteArray jbyteData, jint jwidth, jint jheight){    int rt = 0;    //取输入的YUV图像数据指针    jbyte * in_bytes = (jbyte *)(env)->GetByteArrayElements(jbyteData, 0);    unsigned char * yuv420data = (unsigned char*)in_bytes;    jbyteArray resultByteArray = (env)->NewByteArray( 128);    jbyte *jresults = (env)->GetByteArrayElements(resultByteArray, 0);    //保存结果的数组    unsigned char *results = (unsigned char *)jresults;    int width = jwidth;    int height = jheight;    //开始识别,注意返回值,看是不是成功识别了。    rt = yuv420sp_ocr(results, yuv420data, width, height);    if (rt < 0)        results[0] = rt;    //设置返回JAVA数组结果    (env)->SetByteArrayRegion(resultByteArray, 0, 128, jresults);    //释放输入的YUV图像数据指针    (env)->ReleaseByteArrayElements(jbyteData, in_bytes, 0);    return resultByteArray;}int yuv420sp_ocr(unsigned char *results, unsigned char  * yuvdata, int width, int height){    int ret = 0;    IplImage *image;    image = cvCreateImage(cvSize(width, height), IPL_DEPTH_8U, 1);    int i, j;    for (j = 0; j < height; j++)    {        unsigned char *pPix = (unsigned char *)image->imageData + j*image->widthStep;        unsigned char *pY = yuvdata + j*width;        for (i = 0; i < width; i++)        {            pPix[i] = pY[i];        }    }    //    ret = table_recognition(image, results);    //结束,释放图像    cvReleaseImage(&image);    return ret;}