From e106dfb541412f60781bf872a24cd85e50f43212 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期二, 18 四月 2017 11:56:26 +0800
Subject: [PATCH] 

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java |   97 ++++++++++++++++++++++++++++--------------------
 1 files changed, 57 insertions(+), 40 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 9a211f2..e7601fc 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,19 +1,38 @@
 package cn.com.basic.face.util;
 
-import android.util.Base64;
+import android.graphics.Bitmap;
+import android.util.Log;
 import android.view.Surface;
 
-import org.xutils.http.RequestParams;
+import java.io.ByteArrayInputStream;
+import java.io.InputStream;
+import java.nio.ByteBuffer;
+import java.util.ArrayList;
+import java.util.List;
 
-import java.io.File;
-import java.io.FileOutputStream;
+import cn.com.basic.face.base.MainActivity;
+import cn.com.basic.face.fragment.RegisterFragment;
+import cn.com.basic.face.service.SurveillanceMng;
 
-import cn.com.basic.face.base.BaseApplication;
-import cn.com.basic.face.service.RegisterMng;
+class NativeImgIdx {
+    public int offset;
+    public int size;
+    public int type;
+    public int width;
+    public int height;
+}
+
+class RefByteArray
+{
+    public byte[] arr;
+}
 
 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);
@@ -21,53 +40,51 @@
     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, byte[] faceListPb);
-    public static native int getFaceImages(int cameraIdx, int[] faceImagesIdx, byte[] faceImages);
+    public static native int getFaceList(int cameraIdx, RefByteArray faceListPb);
+    public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages);
 
-    static int i = 1;
     public static void faceCallBack(int cameraIdx, int count)
     {
+        Log.i("@@@", "RtspFaceNative.faceCallBack, cameraIdx=" + cameraIdx + ", count=" + count);
+
+        // something else
+        if (count <= 0)
+            return;
+
         lockFace(cameraIdx);
 
-        byte[] faceListPb = new byte[1024 * 1024 * 1];
+        RefByteArray faceListPb = new RefByteArray();
         int s = getFaceList(cameraIdx, faceListPb);
+        Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraIdx + ", size=" + s);
 
-        //;byte(faceListPb,s)
+        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);
 
-
-        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();
+        try{
+            List<Bitmap> bitmapList = new ArrayList();
+            for (int i = 0; i < faceImagesIdx.size(); i++) {
+                if (i >= 1) {
+                    break;
+                }
+                NativeImgIdx item = faceImagesIdx.get(i);
+                int offset = item.offset;
+                int size = item.size;
+                Bitmap bitmap = Bitmap.createBitmap(item.width,item.height, Bitmap.Config.RGB_565);
+                ByteBuffer byteBuffer = ByteBuffer.wrap(faceImages.arr, offset, size);
+                bitmap.copyPixelsFromBuffer(byteBuffer);
+                bitmapList.add(bitmap);
             }
-            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) {
+            SurveillanceMng.getInstance().addBitmap(bitmapList, faceListPb.arr, s);
+
+        }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