From fe86d1a65b1d7c78384f22db2e5cf09ffe8ad7a1 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期二, 25 四月 2017 15:35:50 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 81 +++++++++++++++++++++++++++++----------- 1 files changed, 59 insertions(+), 22 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 e7601fc..2d6c4af 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,6 +1,7 @@ package cn.com.basic.face.util; import android.graphics.Bitmap; +import android.util.Base64; import android.util.Log; import android.view.Surface; @@ -11,8 +12,13 @@ import java.util.List; 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. + */ class NativeImgIdx { public int offset; @@ -25,7 +31,18 @@ class RefByteArray { public byte[] arr; + public byte[][] arr2; } + +class NativeImg +{ + public int size; + public int type; + public int width; + public int height; + public byte[] image; +} + public class RtspFaceNative { @@ -41,50 +58,70 @@ 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 ArrayList<NativeImgIdx> getFaceImages(int cameraIdx, RefByteArray faceImages); + public static native ArrayList<NativeImg> getFaceImages(int cameraIdx); - public static void faceCallBack(int cameraIdx, int count) + public static void faceCallBack(int cameraInOrOut, int count) { - Log.i("@@@", "RtspFaceNative.faceCallBack, cameraIdx=" + cameraIdx + ", count=" + count); + Log.i("@@@", "RtspFaceNative.faceCallBack, cameraIdx=" + cameraInOrOut + ", count=" + count); // something else if (count <= 0) return; - lockFace(cameraIdx); + lockFace(cameraInOrOut); RefByteArray faceListPb = new RefByteArray(); - int s = getFaceList(cameraIdx, faceListPb); - Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraIdx + ", size=" + s); + int s = getFaceList(cameraInOrOut, faceListPb); + Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraInOrOut + ", 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(cameraInOrOut); int c = 0; - if (faceImagesIdx != null) - c = faceImagesIdx.size(); - Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c); + if (faceImages != null) + c = faceImages.size(); + Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraInOrOut + ", count=" + c); + + for (int i = 0; i < c; i++) + { + Log.i("@@@", "cameraIdx=" + cameraInOrOut + + ", 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]); + } 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; + 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.RGB_565); - ByteBuffer byteBuffer = ByteBuffer.wrap(faceImages.arr, offset, size); + ByteBuffer byteBuffer = ByteBuffer.wrap(item.image, offset, size); bitmap.copyPixelsFromBuffer(byteBuffer); - bitmapList.add(bitmap); + 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); + SurveillanceMng.getInstance().addBitmap(bitmapList, faceListPb.arr, s, cameraInOrOut+""); }catch(Exception e){ e.printStackTrace(); } - releaseFace(cameraIdx); + releaseFace(cameraInOrOut); } } -- Gitblit v1.8.0