From 4c80106fc15aed5f393200f00371c70a2ed22838 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 27 四月 2017 10:51:26 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java | 57 +++++++++++++++++++++------------------------------------ 1 files changed, 21 insertions(+), 36 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 1948e1e..6aaed08 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 @@ -1,6 +1,5 @@ package cn.com.basic.face.service; -import android.graphics.Bitmap; import android.util.Base64; import org.xutils.http.RequestParams; @@ -31,39 +30,12 @@ if (!BaseApplication.deviceAvailable) { return; } - 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.setRegisterOrCheckIn(CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE); - } else { - item.setRegisterOrCheckIn(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); - } - } - }); } - 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; } - final int cameraInOrOut = Integer.parseInt(CommonVariables.Camera.IN); 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().getDeviceCompanyId()); @@ -84,7 +56,11 @@ ) { newList.add(0, item); if (i < bitmapList.size()) { - item.setBitmap(bitmapList.get(i)); + SurveillanceQueryItem surveillanceQueryItem = bitmapList.get(i); + item.setBitmap(surveillanceQueryItem.getBitmap()); + item.setBase64Image(surveillanceQueryItem.getBase64Image()); + item.setWidth(surveillanceQueryItem.getWidth()); + item.setHeight(surveillanceQueryItem.getHeight()); } } } @@ -95,7 +71,7 @@ prevList.addAll(0, newList); - fillBlank(prevList, doubleList); + registerTopAndCheckInBottom(prevList, doubleList); SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true); } @@ -104,17 +80,26 @@ }); } - private void fillBlank(List<SurveillanceQueryItem> list, List<SurveillanceQueryItem> doubleList) { + private void registerTopAndCheckInBottom(List<SurveillanceQueryItem> list, List<SurveillanceQueryItem> doubleList) { doubleList.clear(); List<SurveillanceQueryItem> registerList = new ArrayList<SurveillanceQueryItem>(); List<SurveillanceQueryItem> checkInList = new ArrayList<SurveillanceQueryItem>(); - removeDuplicate(list); + removeDuplicateCheckIn(list); + int maxRegister = 20; + int i1 = 0, j = 0; + int maxCheckIn = 20; for (SurveillanceQueryItem item : list) { if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE) { - registerList.add(item); + if (i1 < maxRegister) { + registerList.add(item); + i1++; + } } if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) { - checkInList.add(item); + if (j < maxCheckIn) { + checkInList.add(item); + j++; + } } } @@ -143,7 +128,7 @@ } - private void removeDuplicate(List<SurveillanceQueryItem> list) { + private void removeDuplicateCheckIn(List<SurveillanceQueryItem> list) { List itemsToRemove = new ArrayList(); Set<String> registerIds = new HashSet<>(); for (SurveillanceQueryItem item : list) { -- Gitblit v1.8.0