From 89e407127b602ad5f81711a92e046ee60eb43935 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期三, 12 四月 2017 10:02:04 +0800
Subject: [PATCH]
---
/dev/null | 33 ----------------
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java | 14 +++++--
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 70 +++++++++++++++++++++++++++++++++++
3 files changed, 80 insertions(+), 37 deletions(-)
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java
index 01b05da..ec2463c 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java
@@ -10,7 +10,7 @@
import cn.com.basic.face.base.BaseFragment;
-import com.bsk.zhangbo.demoforbsk.util.RtspFaceNative;
+import cn.com.basic.face.util.RtspFaceNative;
import cn.com.basic.face.service.SurveillanceMng;
import cn.com.basic.face.widget.surveilance.SurveillanceBottomListView;
@@ -36,10 +36,15 @@
@ViewInject(R.id.fragment_supervisory_exit_camera)
VideoView fragment_supervisory_exit_camera;
- static boolean useNative = false;
+ static boolean useNative = true;
static {
if (useNative) {
+ System.loadLibrary("cvface_api");
+ System.loadLibrary("opencv_java3");
+ System.loadLibrary("protobuf-lite");
+ System.loadLibrary("protobuf");
+ System.loadLibrary("protoc");
System.loadLibrary("rtspface");
RtspFaceNative.init();
}
@@ -73,9 +78,10 @@
Thread.sleep(2000);
if (useNative) {
RtspFaceNative.setSurface(1, fragment_supervisory_enter_camera.getHolder().getSurface());
- RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface());
+ //RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface());
RtspFaceNative.createPlayer(1, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
- RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
+ //RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
+ RtspFaceNative.setFaceCallback(1, "cn/com/basic/face/util/RtspFaceNative", "faceCallBack");
} else {
}
} catch (Exception e) {
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
new file mode 100644
index 0000000..10dbff8
--- /dev/null
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
@@ -0,0 +1,70 @@
+package cn.com.basic.face.util;
+
+import android.util.Base64;
+import android.view.Surface;
+
+import org.xutils.http.RequestParams;
+
+import java.io.File;
+import java.io.FileOutputStream;
+
+import cn.com.basic.face.base.BaseApplication;
+import cn.com.basic.face.service.RegisterMng;
+
+public class RtspFaceNative {
+
+ public static native void init();
+ 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);
+ // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
+ 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);
+
+ 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);
+
+ 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;};//鍥剧墖
+
+}
diff --git a/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java b/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java
deleted file mode 100644
index 98a10b3..0000000
--- a/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java
+++ /dev/null
@@ -1,33 +0,0 @@
-package com.bsk.zhangbo.demoforbsk.util;
-
-import android.view.Surface;
-
-/**
- * Created by xiuxi on 2017/3/21.
- */
-
-public class RtspFaceNative {
-
- public static native void init();
- 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);
- // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
- public static native boolean setFaceCallback(int cameraIdx, String func);
- public static native void lockFace(int cameraIdx);
- public static native void releaseFace(int cameraIdx);
- public static native boolean getFaceList(int cameraIdx, byte[] faceListPb);
- public static native boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages);
-
-// 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