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