2010-09-22 01:47:11 +00:00
|
|
|
#include "image_pool.h"
|
|
|
|
|
|
|
|
#include "yuv420sp2rgb.h"
|
|
|
|
|
2011-04-06 14:31:03 +00:00
|
|
|
#include "android_logger.h"
|
|
|
|
|
2010-09-22 01:47:11 +00:00
|
|
|
#include <opencv2/imgproc/imgproc.hpp>
|
2011-04-06 14:31:03 +00:00
|
|
|
|
|
|
|
#include <cstdlib>
|
2010-11-29 08:37:41 +00:00
|
|
|
#include <jni.h>
|
2011-04-06 14:31:03 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
|
|
|
JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved);
|
|
|
|
//
|
|
|
|
//JNIEXPORT jobject JNICALL Java_com_opencv_jni_opencvJNI_getBitmapBuffer(
|
|
|
|
// JNIEnv *jenv, jclass jcls, jlong jarg1, jobject jarg1_);
|
2010-11-27 07:59:22 +00:00
|
|
|
|
2011-04-06 14:31:03 +00:00
|
|
|
|
|
|
|
JNIEXPORT void JNICALL Java_com_opencv_jni_opencvJNI_addYUVtoPool(JNIEnv *, jclass, jlong, jobject, jbyteArray, jint,
|
|
|
|
jint, jint, jboolean);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
using namespace cv;
|
2010-09-26 18:12:42 +00:00
|
|
|
|
|
|
|
JNIEXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved)
|
|
|
|
{
|
2010-11-27 07:59:22 +00:00
|
|
|
JNIEnv *env;
|
|
|
|
LOGI("JNI_OnLoad called for opencv");
|
|
|
|
return JNI_VERSION_1_4;
|
2010-09-26 18:12:42 +00:00
|
|
|
}
|
2010-09-22 01:47:11 +00:00
|
|
|
|
2010-11-28 05:41:50 +00:00
|
|
|
JNIEXPORT void JNICALL Java_com_opencv_jni_opencvJNI_addYUVtoPool(JNIEnv * env, jclass thiz, jlong ppool,
|
2011-04-06 14:31:03 +00:00
|
|
|
jobject _jpool, jbyteArray jbuffer, jint jidx,
|
|
|
|
jint jwidth, jint jheight, jboolean jgrey)
|
2010-11-27 07:59:22 +00:00
|
|
|
{
|
2010-11-28 05:41:50 +00:00
|
|
|
int buff_height = jheight + (jheight / 2);
|
|
|
|
Size buff_size(jwidth, buff_height);
|
|
|
|
image_pool *pool = (image_pool *)ppool;
|
2010-09-22 01:47:11 +00:00
|
|
|
|
2010-11-27 07:59:22 +00:00
|
|
|
Mat mat = pool->getYUV(jidx);
|
2011-04-06 14:31:03 +00:00
|
|
|
//create is smart and only copies if the buffer size is different
|
|
|
|
mat.create(buff_size, CV_8UC1);
|
2010-11-27 07:59:22 +00:00
|
|
|
{
|
2011-04-06 14:31:03 +00:00
|
|
|
uchar* buff = mat.ptr<uchar> (0);
|
|
|
|
jsize sz = env->GetArrayLength(jbuffer);
|
|
|
|
//http://elliotth.blogspot.com/2007/03/optimizing-jni-array-access.html
|
|
|
|
env->GetByteArrayRegion(jbuffer, 0, sz, (jbyte*)buff);
|
2010-11-27 07:59:22 +00:00
|
|
|
}
|
|
|
|
pool->addYUVMat(jidx, mat);
|
2010-09-22 01:47:11 +00:00
|
|
|
|
2011-04-06 14:31:03 +00:00
|
|
|
Mat color;
|
2010-11-27 07:59:22 +00:00
|
|
|
if (jgrey)
|
|
|
|
{
|
|
|
|
Mat grey = pool->getGrey(jidx);
|
|
|
|
color = grey;
|
|
|
|
}
|
2011-04-06 14:31:03 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
color = pool->getImage(jidx);
|
|
|
|
pool->convertYUVtoColor(jidx, color);
|
|
|
|
}
|
2010-11-27 07:59:22 +00:00
|
|
|
pool->addImage(jidx, color);
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
|
|
|
|
2010-11-27 07:59:22 +00:00
|
|
|
image_pool::image_pool()
|
|
|
|
{
|
2010-09-22 01:47:11 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-11-27 07:59:22 +00:00
|
|
|
image_pool::~image_pool()
|
|
|
|
{
|
2011-04-06 14:31:03 +00:00
|
|
|
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
|
|
|
|
2010-11-27 07:59:22 +00:00
|
|
|
Mat image_pool::getImage(int i)
|
|
|
|
{
|
|
|
|
return imagesmap[i];
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
2010-11-27 07:59:22 +00:00
|
|
|
Mat image_pool::getGrey(int i)
|
|
|
|
{
|
|
|
|
Mat tm = yuvImagesMap[i];
|
|
|
|
if (tm.empty())
|
|
|
|
return tm;
|
2010-11-28 05:41:50 +00:00
|
|
|
return tm(Range(0, tm.rows * (2.0f / 3)), Range::all());
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
2010-11-27 07:59:22 +00:00
|
|
|
Mat image_pool::getYUV(int i)
|
|
|
|
{
|
|
|
|
return yuvImagesMap[i];
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
2010-11-27 07:59:22 +00:00
|
|
|
void image_pool::addYUVMat(int i, Mat mat)
|
|
|
|
{
|
|
|
|
yuvImagesMap[i] = mat;
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
2010-11-27 07:59:22 +00:00
|
|
|
void image_pool::addImage(int i, Mat mat)
|
|
|
|
{
|
|
|
|
imagesmap[i] = mat;
|
2010-09-22 01:47:11 +00:00
|
|
|
}
|
|
|
|
|
2010-11-28 05:41:50 +00:00
|
|
|
void image_pool::convertYUVtoColor(int i, cv::Mat& out)
|
|
|
|
{
|
|
|
|
Mat yuv = getYUV(i);
|
|
|
|
if (yuv.empty())
|
|
|
|
return;
|
|
|
|
int width = yuv.cols;
|
|
|
|
int height = yuv.rows * (2.0f / 3);
|
|
|
|
out.create(height, width, CV_8UC3);
|
|
|
|
const unsigned char* buff = yuv.ptr<unsigned char> (0);
|
|
|
|
unsigned char* out_buff = out.ptr<unsigned char> (0);
|
|
|
|
color_convert_common(buff, buff + width * height, width, height, out_buff, false);
|
|
|
|
}
|
2011-04-06 14:31:03 +00:00
|
|
|
|
|
|
|
void copyMatToBuffer(char* buffer, const cv::Mat& mat)
|
|
|
|
{
|
|
|
|
memcpy(buffer, mat.data, mat.rows * mat.cols * mat.step1());
|
|
|
|
}
|
|
|
|
void copyBufferToMat(cv::Mat& mat, const char* buffer)
|
|
|
|
{
|
|
|
|
memcpy(mat.data, buffer, mat.rows * mat.cols * mat.step1());
|
|
|
|
}
|
|
|
|
|
|
|
|
void RGB2BGR(const Mat& in, Mat& out)
|
|
|
|
{
|
|
|
|
cvtColor(in, out, CV_RGB2BGR);
|
|
|
|
}
|