OpenCV marker detection successfully ported.

This commit is contained in:
2014-03-12 16:34:52 -04:30
parent 09dbc71b29
commit 5773b11e15
3 changed files with 30 additions and 36 deletions

View File

@@ -31,6 +31,7 @@
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<application
android:icon="@drawable/ic_launcher"

View File

@@ -19,7 +19,7 @@
#include "marker.hpp"
#define CAN_LOG
//#define CAN_LOG
extern "C"{
#ifdef CAN_LOG
@@ -37,10 +37,8 @@ const char * TAG = "CVPROC_NATIVE";
JNIEXPORT void JNICALL Java_ve_ucv_ciens_ccg_nxtar_MainActivity_getMarkerCodesAndLocations(
JNIEnv* env,
jobject jobj,
jint width,
jint height,
jbyteArray yuv,
jintArray bgra,
jlong addrMatIn,
jlong addrMatOut,
jintArray codes
){
char codeMsg[128];
@@ -48,19 +46,12 @@ const char * TAG = "CVPROC_NATIVE";
log(TAG, "Requesting native data.");
jbyte* _yuv = env->GetByteArrayElements(yuv, 0);
jint * _bgra = env->GetIntArrayElements(bgra, 0);
cv::Mat& myuv = *(cv::Mat*)addrMatIn;
cv::Mat& mbgr = *(cv::Mat*)addrMatOut;
jint * _codes = env->GetIntArrayElements(codes, 0);
log(TAG, "Converting native data to OpenCV Mats.");
cv::Mat myuv(height + height/2, width, CV_8UC1, (unsigned char *)_yuv);
cv::Mat mbgra(height, width, CV_8UC4, (unsigned char *)_bgra);
log(TAG, "Converting color space before processing.");
cv::Mat mbgr(height, width, CV_8UC3);
cv::Mat gray;
cv::cvtColor(myuv, mbgr, CV_YUV420sp2BGR);
cv::cvtColor(myuv, mbgr, CV_RGB2BGR);
log(TAG, "Finding markers.");
nxtar::getAllMarkers(vCodes, mbgr);
@@ -73,14 +64,8 @@ const char * TAG = "CVPROC_NATIVE";
}
vCodes.clear();
log(TAG, "Converting color space after processing.");
cv::cvtColor(mbgr, gray, CV_BGR2GRAY);
cv::cvtColor(gray, mbgra, CV_GRAY2BGRA, 4);
log(TAG, "Releasing native data.");
env->ReleaseIntArrayElements(codes, _codes, 0);
env->ReleaseIntArrayElements(bgra, _bgra, 0);
env->ReleaseByteArrayElements(yuv, _yuv, 0);
}
}

View File

@@ -16,11 +16,13 @@
package ve.ucv.ciens.ccg.nxtar;
import java.io.ByteArrayOutputStream;
import java.nio.ByteBuffer;
import org.opencv.android.BaseLoaderCallback;
import org.opencv.android.LoaderCallbackInterface;
import org.opencv.android.OpenCVLoader;
import org.opencv.android.Utils;
import org.opencv.core.Mat;
import org.opencv.imgproc.Imgproc;
import ve.ucv.ciens.ccg.nxtar.interfaces.CVProcessor;
import ve.ucv.ciens.ccg.nxtar.interfaces.MulticastEnabler;
@@ -28,8 +30,8 @@ import ve.ucv.ciens.ccg.nxtar.interfaces.Toaster;
import android.content.Context;
import android.content.pm.ActivityInfo;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Bitmap.CompressFormat;
import android.graphics.BitmapFactory;
import android.net.wifi.WifiManager;
import android.net.wifi.WifiManager.MulticastLock;
import android.os.Bundle;
@@ -53,14 +55,14 @@ public class MainActivity extends AndroidApplication implements Toaster, Multica
private BaseLoaderCallback loaderCallback;
private final ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
static{
System.loadLibrary("cvproc");
/*if (!OpenCVLoader.initDebug()){
/*static{
if (!OpenCVLoader.initDebug()){
Gdx.app.exit();
}*/
}
System.loadLibrary("cvproc");
}*/
public native void getMarkerCodesAndLocations(int w, int h, byte[] yuv, int[] rgba, int[] codes);
public native void getMarkerCodesAndLocations(long inMat, long outMat, int[] codes);
@Override
public void onCreate(Bundle savedInstanceState){
@@ -89,6 +91,7 @@ public class MainActivity extends AndroidApplication implements Toaster, Multica
public void onManagerConnected(int status){
switch(status){
case LoaderCallbackInterface.SUCCESS:
System.loadLibrary("cvproc");
ocvOn = true;
break;
default:
@@ -150,16 +153,21 @@ public class MainActivity extends AndroidApplication implements Toaster, Multica
public CVData processFrame(byte[] frame, int w, int h) {
if(ocvOn){
int codes[] = new int[15];
int [] pData = new int[w * h];
Bitmap mFrame = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
Bitmap tFrame = BitmapFactory.decodeByteArray(frame, 0, frame.length);
ByteBuffer buffer = ByteBuffer.allocate(tFrame.getByteCount());
Bitmap tFrame, mFrame;
tFrame.copyPixelsToBuffer(buffer);
tFrame = BitmapFactory.decodeByteArray(frame, 0, frame.length);
getMarkerCodesAndLocations(w, h, buffer.array(), pData, codes);
Mat inImg = new Mat();
Mat outImg = new Mat();
Utils.bitmapToMat(tFrame, inImg);
mFrame.setPixels(pData, 0, w, 0, 0, w, h);
getMarkerCodesAndLocations(inImg.getNativeObjAddr(), outImg.getNativeObjAddr(), codes);
Mat temp = new Mat();
Imgproc.cvtColor(outImg, temp, Imgproc.COLOR_BGR2RGB);
mFrame = Bitmap.createBitmap(temp.cols(), temp.rows(), Bitmap.Config.RGB_565);
Utils.matToBitmap(temp, mFrame);
mFrame.compress(CompressFormat.JPEG, 100, outputStream);
CVData data = new CVData();