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/service/SurveillanceMng.java | 132 ++++++++++++++++++++++--------------------- 1 files changed, 67 insertions(+), 65 deletions(-) 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 901937e..b42df6c 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 @@ -6,15 +6,15 @@ import org.xutils.http.RequestParams; import org.xutils.x; -import java.nio.ByteBuffer; import java.util.ArrayList; +import java.util.HashSet; import java.util.List; +import java.util.Set; 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; @@ -28,92 +28,79 @@ } public void findSurveillanceBottomList(final boolean isVisit) { - RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.SURVEILLANCE_QUERY); - params.addBodyParameter(CommonVariables.Page.PAGE_NUM, "1"); - params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "10"); - x.http().post(params, new BaseCommonCallBack() { - public void success() { - List<SurveillanceQueryItem> list = getList(SurveillanceQueryItem.class); - if (isVisit) { - int i = 0; - for (SurveillanceQueryItem item : list) { - if (i % 5 == 0) { - item.setType(CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE); - } else { - item.setType(CommonVariables.Surveillance.VISIT_CHECK_IN_ITEM_TYPE); - } - i++; - } - - List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>(); - fillBlank(list, doubleList); - - SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true); - } else { - SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_attendance_list_view().show(list, true); - } - } - }); + if (!BaseApplication.deviceAvailable) { + return; + } } - public List getRegisterList() { - return new ArrayList(); - } - - public List getCheckInList() { - return new ArrayList(); - } - - public void getList() { - List registerList = new ArrayList(); - List checkInList = new ArrayList(); - List blendInList = blendIn(registerList, checkInList); - SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(null, true); - } - - public List blendIn(List registerList, List checkInList) { - return null; - } - - public void addBitmap(final List<Bitmap> bitmapList, byte[] byteArray, int len) { + public void addBitmap(final List<SurveillanceQueryItem> bitmapList, byte[] byteArray, int len, String cameraInOrOut) { + if (!BaseApplication.deviceAvailable) { + return; + } 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("deviceCompanyId", BaseApplication.getInstance().getDevice().getDeviceCompanyId()); params.addBodyParameter("deviceId", BaseApplication.getInstance().getDevice().getDeviceId()); - params.addBodyParameter("enterOrExit", CommonVariables.EnterOrExit.ENTER+""); + params.addBodyParameter("InOrOutCamera", cameraInOrOut+""); x.http().post(params, new BaseCommonCallBack() { public void success() { - 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> items = getList(SurveillanceQueryItem.class); + List prevList = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().getPrevList(); + + List newList = new ArrayList(); + + for (int i = 0; items != null && i < items.size(); i++) { + SurveillanceQueryItem item = items.get(i); + int type = item.getRegisterOrCheckIn(); + if (type == CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE + || type == CommonVariables.Surveillance.VISIT_CHECK_IN_ITEM_TYPE + ) { + newList.add(0, item); + if (i < bitmapList.size()) { + SurveillanceQueryItem surveillanceQueryItem = bitmapList.get(i); + item.setBitmap(surveillanceQueryItem.getBitmap()); + item.setBase64Image(surveillanceQueryItem.getBase64Image()); + item.setWidth(surveillanceQueryItem.getWidth()); + item.setHeight(surveillanceQueryItem.getHeight()); + } + } + } + + if (newList.size() > 0) { + List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>(); - List list = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().getPrevList(); - list.add(0, item); + prevList.addAll(0, newList); - fillBlank(list, doubleList); + fillBlank(prevList, 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) { doubleList.clear(); List<SurveillanceQueryItem> registerList = new ArrayList<SurveillanceQueryItem>(); List<SurveillanceQueryItem> checkInList = new ArrayList<SurveillanceQueryItem>(); + removeDuplicate(list); + int maxRegister = 20; + int i1 = 0, j = 0; + int maxCheckIn = 20; for (SurveillanceQueryItem item : list) { - if (item.getType() == Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE) { - registerList.add(item); + if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE) { + if (i1 < maxRegister) { + registerList.add(item); + i1++; + } } - if (item.getType() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) { - checkInList.add(item); + if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) { + if (j < maxCheckIn) { + checkInList.add(item); + j++; + } } } @@ -142,9 +129,24 @@ } + private void removeDuplicate(List<SurveillanceQueryItem> list) { + List itemsToRemove = new ArrayList(); + Set<String> registerIds = new HashSet<>(); + for (SurveillanceQueryItem item : list) { + if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) { + if (registerIds.contains(item.getRegisterId()+"_"+item.getInOrOutCamera())) { + itemsToRemove.add(item); + } else { + registerIds.add(item.getRegisterId()+"_"+item.getInOrOutCamera()); + } + } + } + list.removeAll(itemsToRemove); + } + private SurveillanceQueryItem getBlankItem() { SurveillanceQueryItem blankItem = new SurveillanceQueryItem(); - blankItem.setType(Constant.Surveillance.VISIT_BLANK_ITEM_TYPE); + blankItem.setRegisterOrCheckIn(Constant.Surveillance.VISIT_BLANK_ITEM_TYPE); return blankItem; } -- Gitblit v1.8.0