From f1d499a440c105accf87558aaddd9e155ef1fb82 Mon Sep 17 00:00:00 2001
From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期五, 28 四月 2017 17:12:23 +0800
Subject: [PATCH] optimize
---
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 140 ++++++++++++++++++++++++++++------------------
1 files changed, 86 insertions(+), 54 deletions(-)
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
index f305f04..799349e 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
@@ -1,8 +1,21 @@
package cn.com.basic.face.util;
+import android.graphics.Bitmap;
+import android.util.Base64;
import android.util.Log;
import android.view.Surface;
+
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+import java.nio.ByteBuffer;
import java.util.ArrayList;
+import java.util.List;
+
+import cn.com.basic.face.base.BaseApplication;
+import cn.com.basic.face.base.MainActivity;
+import cn.com.basic.face.discern.query.item.SurveillanceQueryItem;
+import cn.com.basic.face.fragment.RegisterFragment;
+import cn.com.basic.face.service.SurveillanceMng;
/**
* Created by houxiao on 2017/3/21 0021.
@@ -19,13 +32,16 @@
class RefByteArray
{
public byte[] arr;
+ public byte[][] arr2;
}
+
public class RtspFaceNative {
//cn.com.basic.face.util.RtspFaceNative
public static native void init();
+ public static native void setLocalIP(String ipaddr);
public static native void setSurface(int cameraIdx, Surface surface);
public static native boolean createPlayer(int cameraIdx, String uri);
public static native void shutdown(int cameraIdx);
@@ -33,8 +49,15 @@
public static native boolean setFaceCallback(int cameraIdx, String className, String funcName);
public static native void lockFace(int cameraIdx);
public static native void releaseFace(int cameraIdx);
- public static native int getFaceList(int cameraIdx, RefByteArray faceListPb);
- public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages);
+ public static native int getFaceList(int cameraIdx, int dbId, RefByteArray faceListPb);
+ //public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages);
+ public static native ArrayList<NativeImg> getFaceImages(int cameraIdx);
+
+ public static native void dbgFaceAdd(NativeImg faceImage);
+ public static native String dbgGetLog();
+
+
+ public static int COMPANY_ID = 1001;
public static void faceCallBack(int cameraIdx, int count)
{
@@ -47,64 +70,73 @@
lockFace(cameraIdx);
RefByteArray faceListPb = new RefByteArray();
- int s = getFaceList(cameraIdx, faceListPb);
+
+ try {
+ COMPANY_ID = Integer.parseInt(BaseApplication.getInstance().getDevice().getDeviceCompanyId());
+ } catch (Exception e) {
+ COMPANY_ID = 0;
+ }
+
+ int s = getFaceList(cameraIdx, COMPANY_ID, faceListPb);
Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraIdx + ", size=" + s);
- RefByteArray faceImages = new RefByteArray();
- ArrayList<NativeImgIdx> faceImagesIdx = getFaceImages(cameraIdx, faceImages);
+ //RefByteArray faceImages = new RefByteArray();
+ //ArrayList<NativeImgIdx> faceImagesIdx = getFaceImages(cameraIdx, faceImages);
+ //int c = 0;
+ //if (faceImagesIdx != null)
+ // c = faceImagesIdx.size();
+ //Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c);
+
+ ArrayList<NativeImg> faceImages = getFaceImages(cameraIdx);
int c = 0;
- if (faceImagesIdx != null)
- c = faceImagesIdx.size();
+ if (faceImages != null)
+ c = faceImages.size();
Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c);
+
+ for (int i = 0; i < c; i++)
+ {
+ Log.i("@@@", "cameraIdx=" + cameraIdx +
+ ", i=" + i +
+ ", size=" + faceImages.get(i).size+
+ ", w=" + faceImages.get(i).width +
+ ", h=" + faceImages.get(i).height +
+ ", image[0]=" + faceImages.get(i).image[0] +
+ ", image[1]=" + faceImages.get(i).image[1]);
+
+ if (i == 0)
+ {
+ //Bitmap bitmap = Bitmap.createBitmap(faceImages.get(i).width, faceImages.get(i).height, Bitmap.Config.RGB_565);
+ //ByteBuffer byteBuffer = ByteBuffer.wrap(faceImages.get(i).image, 0, faceImages.get(i).size);
+ //bitmap.copyPixelsFromBuffer(byteBuffer);
+ //NativeCodec.setFaceDrawable(bitmap);
+
+ //NativeCodec.setFaceDrawable(faceImages.get(i));
+ }
+ }
+
+ try{
+ List<SurveillanceQueryItem> bitmapList = new ArrayList();
+ for (int i = 0; i < faceImages.size(); i++) {
+ NativeImg item = faceImages.get(i);
+ SurveillanceQueryItem surveillanceQueryItem = new SurveillanceQueryItem();
+ int offset = 0;
+ int size = item.size;
+ Bitmap bitmap = Bitmap.createBitmap(item.width,item.height, Bitmap.Config.ARGB_8888);
+ ByteBuffer byteBuffer = ByteBuffer.wrap(item.image, offset, size);
+ bitmap.copyPixelsFromBuffer(byteBuffer);
+ surveillanceQueryItem.setBase64Image(Base64.encodeToString(item.image, offset, size, Base64.DEFAULT));
+ surveillanceQueryItem.setBitmap(bitmap);
+ surveillanceQueryItem.setWidth(item.width+"");
+ surveillanceQueryItem.setHeight(item.height+"");
+ bitmapList.add(surveillanceQueryItem);
+ }
+ SurveillanceMng.getInstance().addBitmap(bitmapList, faceListPb.arr, s, cameraIdx+"");
+
+ }catch(Exception e){
+ e.printStackTrace();
+ }
releaseFace(cameraIdx);
}
}
-
-
-// static int i = 1;
-// public static void faceCallBack(int cameraIdx, int count)
-// {
-// lockFace(cameraIdx);
-//
-// byte[] faceListPb = new byte[1024 * 1024 * 1];
-// int s = getFaceList(cameraIdx, faceListPb);
-//
-// //;byte(faceListPb,s)
-//
-//
-// int[] faceImagesIdx = new int[10];
-// byte[] faceImages = new byte[1024 * 1024 * 1];
-// int c = getFaceImages(cameraIdx, faceImagesIdx, faceImages);
-//
-// try {
-// File path = BaseApplication.getInstance().getFilesDir();
-// File f1 = new File(path, ""+i);
-// if (!f1.exists()) {
-// f1.createNewFile();
-// }
-// FileOutputStream f = new FileOutputStream(f1);
-// f.write(faceImages);
-// f.close();
-// RequestParams params = new RequestParams();
-// String encodedImage = Base64.encodeToString(faceImages, Base64.DEFAULT);
-// params.addBodyParameter("choosePhoto", encodedImage);
-// RegisterMng.getInstance().add(params);
-// } catch (Exception e) {
-// e.printStackTrace();
-// }
-//
-// releaseFace(cameraIdx);
-// }
-
-// public static void init() {};
-// public static void setSurface(int cameraIdx, Surface surface){};
-// public static boolean createPlayer(int cameraIdx, String uri){return true;};
-// public static void shutdown(int cameraIdx){};
-// // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
-// public static boolean setFaceCallback(int cameraIdx, String func){return true;};
-// public static void lockFace(int cameraIdx){};
-// public static void releaseFace(int cameraIdx){};
-// public static boolean getFaceList(int cameraIdx, byte[] faceListPb){return true;};//浜岃繘鍒�
-// public static boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages){return true;};//鍥剧墖
--
Gitblit v1.8.0