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

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java |   47 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 37 insertions(+), 10 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 21a26e9..9b2ec4d 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
@@ -8,7 +8,9 @@
 
 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;
@@ -67,30 +69,38 @@
         params.addBodyParameter("base64Photo", Base64.encodeToString(byteArray, 0, len, Base64.DEFAULT));
         params.addBodyParameter("deviceCompanyId", BaseApplication.getInstance().getDevice().getDeviceCompanyId());
         params.addBodyParameter("deviceId", BaseApplication.getInstance().getDevice().getDeviceId());
-        params.addBodyParameter("enterOrExit", CommonVariables.EnterOrExit.ENTER+"");
+        params.addBodyParameter("InOrOutCamera", CommonVariables.Camera.IN+"");
         x.http().post(params, new BaseCommonCallBack() {
             public void success() {
                 List<SurveillanceQueryItem> items = getList(SurveillanceQueryItem.class);
-                List list = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().getPrevList();
+                List prevList = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().getPrevList();
 
-                for (int i = 0; i < items.size(); i++) {
+                List newList = new ArrayList();
+
+                for (int i = 0; items != null && i < items.size(); i++) {
                     SurveillanceQueryItem item = items.get(i);
                     int type = item.getType();
                     if (type == CommonVariables.Surveillance.VISIT_REGISTER_ITEM_TYPE
                             || type == CommonVariables.Surveillance.VISIT_CHECK_IN_ITEM_TYPE
                             ) {
-                        list.add(0, item);
-                    }
-                    if (i < bitmapList.size()) {
-                        item.setBitmap(bitmapList.get(i));
+                        newList.add(0, item);
+                        if (i < bitmapList.size()) {
+                            item.setBitmap(bitmapList.get(i));
+                        }
                     }
                 }
 
-                List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>();
+                if (newList.size() > 0) {
 
-                fillBlank(list, doubleList);
+                    List<SurveillanceQueryItem> doubleList = new ArrayList<SurveillanceQueryItem>();
 
-                SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true);
+                    prevList.addAll(0, newList);
+
+                    fillBlank(prevList, doubleList);
+
+                    SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visit_list_view().show(doubleList, true);
+                }
+
             }
         });
     }
@@ -99,6 +109,7 @@
         doubleList.clear();
         List<SurveillanceQueryItem> registerList = new ArrayList<SurveillanceQueryItem>();
         List<SurveillanceQueryItem> checkInList = new ArrayList<SurveillanceQueryItem>();
+        removeDuplicate(list);
         for (SurveillanceQueryItem item : list) {
             if (item.getType() == Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE) {
                 registerList.add(item);
@@ -133,6 +144,22 @@
 
     }
 
+    private void removeDuplicate(List<SurveillanceQueryItem> list) {
+        List itemsToRemove = new ArrayList();
+        Set<String> registerIds = new HashSet<>();
+        for (SurveillanceQueryItem item : list) {
+            if (item.getType() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) {
+                if (registerIds.contains(item.getRegisterId())) {
+                    itemsToRemove.add(item);
+                } else {
+                    registerIds.add(item.getRegisterId());
+                }
+
+            }
+        }
+        list.removeAll(itemsToRemove);
+    }
+
     private SurveillanceQueryItem getBlankItem() {
         SurveillanceQueryItem blankItem = new SurveillanceQueryItem();
         blankItem.setType(Constant.Surveillance.VISIT_BLANK_ITEM_TYPE);

--
Gitblit v1.8.0