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