From 0727355ae017c0153ee7c643cdd1b0611c81627f Mon Sep 17 00:00:00 2001 From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 13 四月 2017 12:04:00 +0800 Subject: [PATCH] bug fix --- VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 25 +++++++++++++++++++++---- 1 files changed, 21 insertions(+), 4 deletions(-) diff --git a/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java b/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java index 4267ef1..c3d09ad 100644 --- a/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java +++ b/VisitFace/RtspNativeCodec/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java @@ -8,6 +8,19 @@ * Created by houxiao on 2017/3/21 0021. */ +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 @@ -20,20 +33,24 @@ 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 ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, byte[] faceImages); + public static native int getFaceList(int cameraIdx, RefByteArray faceListPb); + public static native ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages); 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[] faceImages = new byte[1024 * 1024 * 1]; + RefByteArray faceImages = new RefByteArray(); ArrayList<NativeImgIdx> faceImagesIdx = getFaceImages(cameraIdx, faceImages); int c = 0; if (faceImagesIdx != null) -- Gitblit v1.8.0