From 9e5babf9db52e64bdae60137be7696e56241fca6 Mon Sep 17 00:00:00 2001
From: xingzilong <xingzilong@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期五, 18 八月 2017 18:12:17 +0800
Subject: [PATCH] H264 NALU解析  并在RTSPServer判断

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/SurveillanceMng.java |  217 ++++++++++++++++++++----------------------------------
 1 files changed, 81 insertions(+), 136 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 3189a6b..0cebae6 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,22 +1,25 @@
 package cn.com.basic.face.service;
 
-import android.util.Base64;
-
 import org.xutils.http.RequestParams;
 import org.xutils.x;
 
-import java.util.ArrayList;
-import java.util.HashSet;
+import java.io.File;
+import java.io.FileWriter;
 import java.util.List;
-import java.util.Set;
 
 import cn.com.basic.face.base.BaseApplication;
+import cn.com.basic.face.base.MainActivity;
 import cn.com.basic.face.discern.common.BaseCommonCallBack;
 import cn.com.basic.face.discern.common.CommonVariables;
+import cn.com.basic.face.discern.common.SqliteSqlBean;
 import cn.com.basic.face.discern.query.item.SurveillanceQueryItem;
-import cn.com.basic.face.fragment.SurveillanceFragment;
+import cn.com.basic.face.discern.query.item.UnknownQueryItem;
+import cn.com.basic.face.service.sqlite.SurveillanceDao;
 import cn.com.basic.face.util.AppApi;
-import cn.com.basic.face.util.Constant;
+import cn.com.basic.face.util.FileUtil;
+import cn.com.basic.face.util.SqliteSqlUtil;
+import cn.com.basic.face.util.SurveillanceQueryItemUtil;
+import cn.com.basic.face.util.UnknownSurveillanceQueryItemUtil;
 
 public class SurveillanceMng {
 
@@ -26,146 +29,88 @@
         return instance;
     }
 
-    public void findSurveillanceBottomList(final boolean isVisit) {
-        if (!BaseApplication.deviceAvailable) {
-            return;
-        }
-        List attendanceList = new ArrayList();
-        for (int i = 0; i < 10; i++) {
-            SurveillanceQueryItem item = new SurveillanceQueryItem();
-            item.setInOrOutCamera(CommonVariables.Camera.IN);
-            item.setUsername("zhangsan");
-            attendanceList.add(item);
-        }
-        SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_attendance_list_view().show(attendanceList);
+    public void addOfflineBitmap(final List<SurveillanceQueryItem> bitmapList, final byte[] rawData, final String cameraInOrOut) {
+        SurveillanceDao.getInstance().saveOfflineUnknownToLocal(bitmapList, rawData, cameraInOrOut);
+        UnknownSurveillanceQueryItemUtil.getInstance().addItems(bitmapList);
     }
 
-    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().getDeviceCompanyId());
-        params.addBodyParameter("deviceId", BaseApplication.getInstance().getDevice().getDeviceId());
-        params.addBodyParameter("InOrOutCamera", cameraInOrOut+"");
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                List<SurveillanceQueryItem> items = getList(SurveillanceQueryItem.class);
-                List prevVisitorList = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visitor_list_view().getPrevList();
-                List prevAttendanceList = SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_attendance_list_view().getPrevList();
-
-                List newVisitorList = new ArrayList();
-
-                List newAttendanceList = 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
-                            ) {
-                        newVisitorList.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());
+    public static class SurveillanceListThread extends Thread {
+        @Override
+        public void run() {
+            try {
+                while (true) {
+                    MainActivity.getInstance().runOnUiThread(new Runnable() {
+                        @Override
+                        public void run() {
+                            if (BaseApplication.getInstance().networkAvailable()) {
+                                SurveillanceQueryItemUtil.getInstance().removeTimeoutItemAndShow();
+                            } else {
+                                UnknownSurveillanceQueryItemUtil.getInstance().removeTimeoutItemAndShow();
+                            }
                         }
-                    }
-                    if (type ==  CommonVariables.Surveillance.VISIT_ATTENDANCE_ITEM_TYPE) {
-                        newAttendanceList.add(item);
-                    }
+                    });
+                    Thread.sleep(1000*60*5);
                 }
-
-                if (newVisitorList.size() > 0) {
-                    prevVisitorList.addAll(0, newVisitorList);
-                    registerTopAndCheckInBottom(prevVisitorList);
-                    SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_visitor_list_view().show(prevVisitorList);
-                }
-
-                if (newAttendanceList.size() > 0) {
-                    prevAttendanceList.addAll(0, newAttendanceList);
-                    if (prevAttendanceList.size() > 20) {
-                        prevAttendanceList = prevAttendanceList.subList(0, 20);
-                    }
-                    SurveillanceFragment.getInstance().get_fragment_supervisory_bottom_attendance_list_view().show(prevAttendanceList);
-                }
-
-            }
-        });
-    }
-
-    private void registerTopAndCheckInBottom(List<SurveillanceQueryItem> list) {
-        List<SurveillanceQueryItem> registerList = new ArrayList<SurveillanceQueryItem>();
-        List<SurveillanceQueryItem> checkInList = new ArrayList<SurveillanceQueryItem>();
-        removeDuplicateCheckIn(list);
-        int i1 = 0, j = 0;
-        int maxRegister = 50;
-        int maxCheckIn = 50;
-        for (SurveillanceQueryItem item : list) {
-            if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_REGISTER_ITEM_TYPE) {
-                if (i1 < maxRegister) {
-                    registerList.add(item);
-                    i1++;
-                }
-            }
-            if (item.getRegisterOrCheckIn() == Constant.Surveillance.VISIT_CHECK_IN_ITEM_TYPE) {
-                if (j < maxCheckIn) {
-                    checkInList.add(item);
-                    j++;
-                }
+            } catch (Exception e) {
+                e.printStackTrace();
             }
         }
-
-        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++) {
-            SurveillanceQueryItem item;
-            if (i % 2 == 0) {
-                if (m < registerList.size()) {
-                    item = registerList.get(m);
-                } else {
-                    item = getBlankItem();
-                }
-                m++;
-            } else {
-                if (n < checkInList.size()) {
-                    item = checkInList.get(n);
-                } else {
-                    item = getBlankItem();
-                }
-                n++;
-            }
-            tempList.add(item);
-        }
-        list.clear();
-        list.addAll(tempList);
     }
 
-    private void removeDuplicateCheckIn(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());
-                }
-            }
+    int fileIndex = 1;
+
+    public void addBitmap(final List<SurveillanceQueryItem> bitmapList, final byte[] byteArray, int len, final String cameraInOrOut, byte[] surveillancePhotoBytes) {
+        if (!BaseApplication.deviceAvailable) {
+            return;
         }
-        list.removeAll(itemsToRemove);
+        try {
+            if (fileIndex > 30) {
+                fileIndex = 1;
+            }
+            fileIndex++;
+            RequestParams params = new RequestParams();
+            File rawSurveillancePhotoFile = FileUtil.writeToFile("rawSurveillancePhotoFile_"+fileIndex, byteArray);
+            File surveillancePhotoFile = FileUtil.writeToFile("surveillancePhotoFile_"+fileIndex, surveillancePhotoBytes);
+
+            params.addBodyParameter("InOrOutCamera", cameraInOrOut + "");
+            params.addBodyParameter("deviceId", BaseApplication.getInstance().getAndroidDevice().getDeviceId());
+            params.addBodyParameter("rawSurveillancePhoto", rawSurveillancePhotoFile);
+            params.addBodyParameter("surveillancePhoto", surveillancePhotoFile);
+
+            File path = BaseApplication.getInstance().getFilesDir();
+            if (!rawSurveillancePhotoFile.exists()) {
+                rawSurveillancePhotoFile.createNewFile();
+            }
+            File f0 = new File(path, "f0");
+            if (!f0.exists()) {
+                f0.createNewFile();
+            }
+
+            FileWriter fw0 = new FileWriter(f0);
+            fw0.write("test1");
+            fw0.close();
+            params.setUri(AppApi.BASE_URL + AppApi.SURVEILLANCE_UPLOAD);
+            params.addBodyParameter("f0", f0);
+            params.addBodyParameter("rawSurveillancePhoto", rawSurveillancePhotoFile);
+            params.addBodyParameter("deviceCompanyId", BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+            x.http().post(params, new BaseCommonCallBack() {
+                @Override
+                public void success() {
+                    try {
+                        SqliteSqlUtil.insert(getExtraList(SqliteSqlBean.class));
+                        SurveillanceQueryItemUtil.getInstance().addItems(resultBean.getList(SurveillanceQueryItem.class), bitmapList, cameraInOrOut);
+                    } catch(Exception e) {
+                        e.printStackTrace();
+                    }
+                }
+            });
+        }catch(Exception e) {
+            e.printStackTrace();
+        }
     }
 
-    private SurveillanceQueryItem getBlankItem() {
-        SurveillanceQueryItem blankItem = new SurveillanceQueryItem();
-        blankItem.setRegisterOrCheckIn(Constant.Surveillance.VISIT_BLANK_ITEM_TYPE);
-        return blankItem;
+    public void removePhotoFileWhenStorageIsSlow() {
+
     }
 
 }

--
Gitblit v1.8.0