From 2d588d61fdee6506af81d05a59e40fdd519cd50d Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期二, 18 四月 2017 15:47:04 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java | 31 +++++++++++---- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/discern/common/CommonVariables.java | 10 +++++ VisitFace/DemoForBsk/app/src/main/jniLibs/armeabi-v7a/librtspface.so | 0 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java | 54 +++++++++++++++++++++------ VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/surveilance/SurveillanceBottomListView.java | 4 ++ 5 files changed, 79 insertions(+), 20 deletions(-) diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/discern/common/CommonVariables.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/discern/common/CommonVariables.java index 6c7c99f..564b981 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/discern/common/CommonVariables.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/discern/common/CommonVariables.java @@ -54,4 +54,14 @@ public static final int reachBottom = 3; } + public static class Surveillance { + public static final int VISIT_REGISTER_ITEM_TYPE = 1; + public static final int VISIT_CHECK_IN_ITEM_TYPE = 2; + public static final int VISIT_BLANK_ITEM_TYPE = 3; + + public static final int REGISTER_CELL_VIEW_INDEX = 0; + public static final int CHECK_IN_CELL_VIEW_INDEX = 1; + public static final int VISIT_BLANK_CELL_VIEW_INDEX = 2; + } + } diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java index 77c53f1..96c2fad 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java @@ -10,9 +10,11 @@ import java.util.ArrayList; import java.util.List; +import cn.com.basic.face.base.BaseApplication; import cn.com.basic.face.discern.common.BaseCommonCallBack; import cn.com.basic.face.discern.common.CommonVariables; import cn.com.basic.face.discern.query.item.SurveillanceQueryItem; +import cn.com.basic.face.fragment.RegisterFragment; import cn.com.basic.face.fragment.SurveillanceFragment; import cn.com.basic.face.util.AppApi; import cn.com.basic.face.util.Constant; @@ -36,9 +38,9 @@ int i = 0; for (SurveillanceQueryItem item : list) { if (i % 5 == 0) { - item.setType(Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE); + item.setType(CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE); } else { - item.setType(Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE); + item.setType(CommonVariables.Surveillance.VISIT_CHECK_IN_ITEM_TYPE); } i++; } @@ -76,17 +78,30 @@ public void addBitmap(final List<Bitmap> bitmapList, byte[] byteArray, int len) { RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.SURVEILLANCE_UPLOAD); params.addBodyParameter("base64Photo", Base64.encodeToString(byteArray, 0, len, Base64.DEFAULT)); + params.addBodyParameter("deviceCompanyId", BaseApplication.getInstance().getDevice().getCompanyId()); + params.addBodyParameter("deviceId", BaseApplication.getInstance().getDevice().getDeviceId()); + params.addBodyParameter("enterOrExit", CommonVariables.EnterOrExit.ENTER+""); x.http().post(params, new BaseCommonCallBack() { public void success() { - String result = ""; - List list = new ArrayList(); - if (result.equals("visit")) { - list.add(0, ""); - } else if (result.equals("register")) { - list.add(0, ""); + SurveillanceQueryItem item = getBean(SurveillanceQueryItem.class); + if (item.getType() == CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE + || item.getType() == CommonVariables.Surveillance.VISIT_CHECK_IN_ITEM_TYPE + ) { + List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>(); + + List list = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().getPrevList(); + list.add(0, item); + + fillBlank(list, doubleList); + + SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true); } + } }); + if (bitmapList != null && bitmapList.size() > 0) { + //RegisterFragment.getInstance().get_fragment_register_choose_photo().setImageBitmap(bitmapList.get(0)); + } } private void fillBlank(List<SurveillanceQueryItem> list, List<SurveillanceQueryItem> doubleList) { 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..ef2ddbb 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 @@ -14,6 +14,10 @@ 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; public int size; @@ -25,7 +29,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,7 +56,8 @@ 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) { @@ -57,24 +73,38 @@ int s = getFaceList(cameraIdx, faceListPb); Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceList, cameraIdx=" + cameraIdx + ", 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(cameraIdx); int c = 0; - if (faceImagesIdx != null) - c = faceImagesIdx.size(); + if (faceImages != null) + c = faceImages.size(); Log.i("@@@", "RtspFaceNative.faceCallBack, getFaceImages, cameraIdx=" + cameraIdx + ", count=" + c); + + for (int i = 0; i < c; i++) + { + Log.i("@@@", "cameraIdx=" + cameraIdx + + ", 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; + for (int i = 0; i < faceImages.size(); i++) { + NativeImg item = faceImages.get(i); + 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); } diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/surveilance/SurveillanceBottomListView.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/surveilance/SurveillanceBottomListView.java index 166bf85..752ed10 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/surveilance/SurveillanceBottomListView.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/surveilance/SurveillanceBottomListView.java @@ -77,4 +77,8 @@ this.setAdapter(mAdapter); } + public List getPrevList() { + return this.list; + } + } diff --git a/VisitFace/DemoForBsk/app/src/main/jniLibs/armeabi-v7a/librtspface.so b/VisitFace/DemoForBsk/app/src/main/jniLibs/armeabi-v7a/librtspface.so index c573675..3e1fa8c 100644 --- a/VisitFace/DemoForBsk/app/src/main/jniLibs/armeabi-v7a/librtspface.so +++ b/VisitFace/DemoForBsk/app/src/main/jniLibs/armeabi-v7a/librtspface.so Binary files differ -- Gitblit v1.8.0