From c7fe31931a26a941ca2adf002e40b47a049a604c Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期四, 27 四月 2017 11:07:57 +0800
Subject: [PATCH] 

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java |   72 +++++++++++++----------------------
 1 files changed, 27 insertions(+), 45 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..0b849c3 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,41 +56,50 @@
                             ) {
                         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());
                         }
                     }
                 }
 
                 if (newList.size() > 0) {
-
-                    List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>();
-
                     prevList.addAll(0, newList);
-
-                    fillBlank(prevList, doubleList);
-
-                    SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true);
+                    registerTopAndCheckInBottom(prevList);
+                    SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(prevList);
                 }
 
             }
         });
     }
 
-    private void fillBlank(List<SurveillanceQueryItem> list, List<SurveillanceQueryItem> doubleList) {
-        doubleList.clear();
+    private void registerTopAndCheckInBottom(List<SurveillanceQueryItem> list) {
         List<SurveillanceQueryItem> registerList = new ArrayList<SurveillanceQueryItem>();
         List<SurveillanceQueryItem> checkInList = new ArrayList<SurveillanceQueryItem>();
-        removeDuplicate(list);
+        removeDuplicateCheckIn(list);
+        int i1 = 0, j = 0;
+        int maxRegister = 20;
+        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++;
+                }
             }
         }
 
         int max = registerList.size() > checkInList.size() ? registerList.size() : checkInList.size();
+
+        List tempList = new ArrayList();
 
         int m = 0, n = 0;
         for (int i = 0; i < max * 2; i++) {
@@ -138,12 +119,13 @@
                 }
                 n++;
             }
-            doubleList.add(item);
+            tempList.add(item);
         }
-
+        list.clear();
+        list.addAll(tempList);
     }
 
-    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