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)
{
    ;
    //取输入的YUV图像数据指针
    jbyte * in_bytes = (jbyte *)(env)->GetByteArrayElements(jbyteData, );
    unsigned char * yuv420data = (unsigned char*)in_bytes;

    jbyteArray resultByteArray = (env)->NewByteArray( );
    jbyte *jresults = (env)->GetByteArrayElements(resultByteArray, );
    //保存结果的数组
    unsigned char *results = (unsigned char *)jresults;

    int width = jwidth;
    int height = jheight;

    //开始识别,注意返回值,看是不是成功识别了。
    rt = yuv420sp_ocr(results, yuv420data, width, height);
    )
        results[] = rt;

    //设置返回JAVA数组结果
    (env)->SetByteArrayRegion(resultByteArray, , , jresults);

    //释放输入的YUV图像数据指针
    (env)->ReleaseByteArrayElements(jbyteData, in_bytes, );
    return resultByteArray;
}

int yuv420sp_ocr(unsigned char *results, unsigned char  * yuvdata, int width, int height)
{
    ;
    IplImage *image;
    image = cvCreateImage(cvSize(width, height), IPL_DEPTH_8U, );

    int i, j;
    ; j < height; j++)
    {
        unsigned char *pPix = (unsigned char *)image->imageData + j*image->widthStep;
        unsigned char *pY = yuvdata + j*width;
        ; i < width; i++)
        {
            pPix[i] = pY[i];
        }
    }

    //
    ret = table_recognition(image, results);

    //结束,释放图像
    cvReleaseImage(&image);
    return ret;
}

opencv 手写选择题阅卷 (四)Android端 手机应用开发的更多相关文章

  1. opencv 手写选择题阅卷 (二)字符识别

    opencv 手写选择题阅卷 (二)字符识别 选择题基本上只需要识别ABCD和空五个内容,理论上应该识别率比较高的,识别代码参考了网上搜索的代码,因为参考的网址比较多,现在也弄不清是参考何处的代码了, ...

  2. opencv 手写选择题阅卷 (三)训练分类器

    opencv 手写选择题阅卷 (三)训练分类器 1,分类器选择:SVM 本来一开始用的KNN分类器,但这个分类器目前没有实现保存训练数据的功能,所以选择了SVN分类器; 2,样本图像的预处理和特征提取 ...

  3. opencv 手写选择题阅卷 (一)表格设计与识别

    (一)答题表格设计与识别 实际设计好的表格如下图 为了图像精确,表格和四角的标记都是由程序生成的,文字和数据是后期排版软件添加上去的. 图中四角的四个黑方块主要用来定位表格,然后就可以切割出每个单元格 ...

  4. Android 个人手机通讯录开发

    一.Android 个人手机通讯录开发 数据存储:SQLite 数据库 开发工具:Android Studio 二.Phone Module 简介 1. 界面展示                2. ...

  5. Android安卓手机游戏开发

    成都传智播客Java培训,免费学Android安卓手机游戏开发,安卓android开发课程包括Android安卓应用开发和Android安卓游戏开发两个方向,可是偏向游戏开发. 依据"199 ...

  6. OpenCV手写数字字符识别(基于k近邻算法)

    摘要 本程序主要参照论文,<基于OpenCV的脱机手写字符识别技术>实现了,对于手写阿拉伯数字的识别工作.识别工作分为三大步骤:预处理,特征提取,分类识别.预处理过程主要找到图像的ROI部 ...

  7. 手写内网穿透服务端客户端(NAT穿透)原理及实现

    Hello,I'm Shendi. 这天心血来潮,决定做一个内网穿透的软件. 用过花生壳等软件的就知道内网穿透是个啥,干嘛用的了. 我们如果有服务器(比如tomcat),实际上我们在电脑上开启了服务器 ...

  8. 【转载】Android端手机测试体系

    1.冒烟测试 跟web端 的测试流程一样,你拿到一个你们开发做出来的apk首先得去冒烟,也就是保证他的稳定性,指定时间内不会崩溃.这款原生sdk自带的monkey可以当做 我们的测试工具.就跟我之前博 ...

  9. Android端手机测试体系

    1.冒烟测试 跟web端的测试流程一样,你拿到一个你们开发做出来的apk首先得去冒烟,也就是保证他的稳定性,指定时间内不会崩溃.这款原生sdk自带的monkey可以当做我们的测试工具.就跟我之前博客所 ...

随机推荐

  1. C#中判断空字符串的3种方法性能分析

    3种方法分别是:string a="";1.if(a=="")2.if(a==String.Empty)3.if(a.Length==0) 3种方法都是等效的, ...

  2. 关于Android与pc通信时中文乱码的分析和解决

    初步实现了Android与pc服务器的通信之后,又碰到了传说中令人头疼不已的中文乱码问题.既然出现了乱码,那么原因自然是协议不通了.我们知道eclipse中默认的编码标准是GBK,而安卓程序开发所默认 ...

  3. 百度地图经纬度转换JS版

    //百度地图的坐标转换,由于百度地图在GCJ02协议的基础上又做了一次处理,变为 BD09协议的坐标,以下是坐标的转化方式,可以方便和其他平台转化 jQuery.MapConvert = { x_pi ...

  4. HDU 4932 贪心

    Miaomiao's Geometry Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Othe ...

  5. mysqldump的流程

    发布时间:2013 年 4 月 6 日 发布者: OurMySQL 来源:P.Linux Laboratory      前几天看到群里在讨论mysqldump导致锁表的问题,为什么一个表已经dump ...

  6. Python 计算程序运行时间

    import time def start_sleep():    time.sleep(3) if __name__ == '__main__':    #The start time     st ...

  7. 开发技巧01——改变Toast显示位置

    1.获得Toast对象——Toast toast = Toast.makeText(this, "Top Left!", Toast.LENGTH_SHORT); 2.Toast对 ...

  8. hadoop学习记录(四)hadoop2.6 hive配置

    一.安装mysql 1安装服务器 sudo apt-get install mysql-server 2安装mysql客户端 sudo apt-get install mysql-client sud ...

  9. [课程相关]homework-02

    一.如何组织代码 因为这个代码比较简单,用函数就足够了,个人觉得没必要用类,杀鸡不必用牛刀. 代码有点长,主要是加了很多判断参数的部分. 提取了一个公共的递归函数. 用了不少全局变量,可能当做参数传入 ...

  10. hdu 4635 强连通度缩点

    思路:想用Tarjan算法进行缩点,并记录每个连通分支的点数.缩点完毕过后,找出所有出度或入度为0的连通分量,假设该连通分量的点数为num[i],那么 ans=Max(ans,(n-num-1)*(n ...