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/VisitMng.java |  105 +++++++++++++++++++++++++++++++++-------------------
 1 files changed, 66 insertions(+), 39 deletions(-)

diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/VisitMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/VisitMng.java
index 11e6b50..2de0adc 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/VisitMng.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/VisitMng.java
@@ -8,13 +8,17 @@
 import java.util.List;
 
 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.ResultBean;
 import cn.com.basic.face.discern.query.condition.VisitQueryCondition;
 import cn.com.basic.face.discern.query.item.VisitQueryItem;
+import cn.com.basic.face.service.sqlite.VisitDao;
 import cn.com.basic.face.util.AppApi;
+import cn.com.basic.face.util.DateUtil;
 
-public class VisitMng {
+public class VisitMng extends BaseMng {
 
     private static VisitMng instance = new VisitMng();
     public static VisitMng getInstance() {
@@ -25,46 +29,69 @@
         if (!BaseApplication.deviceAvailable) {
             return;
         }
-        RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.VISIT_QUERY);
-        params.addBodyParameter(VisitQueryCondition.FieldNames.username, searchText);
-        params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "5");
-        params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+"");
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                List<VisitQueryItem> list = getList(VisitQueryItem.class);
-                List itemList = new ArrayList();
-                int i = 0;
-                String previewDate = "";
-                SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");
-                SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy骞碝M鏈坉d鏃�");
-                for (VisitQueryItem item : list) {
-                    try {
-                        String yearMonthDay = sdf2.format(sdf1.parse(item.getEnterTime()));
-                        if (!previewDate.equals(yearMonthDay)) {
-                            itemList.add(yearMonthDay);
-                            previewDate = yearMonthDay;
-                        }
-                    } catch (Exception e) { }
-                    itemList.add(item);
-                    i++;
+        if (BaseApplication.getInstance().networkAvailable()) {
+            RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.VISIT_QUERY);
+            params.addBodyParameter(VisitQueryCondition.FieldNames.username, searchText);
+            params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE);
+            params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+"");
+            params.addBodyParameter("deviceCompanyId", BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+            x.http().post(params, new BaseCommonCallBack() {
+                public void success() {
+                    findLeftVisitorListAfterReturn(resultBean, append);
                 }
-                if (hasMorePages()) {
-                    itemList.add(CommonVariables.Page.hasMorePages);
-                } else {
-                    if (getPageNum() > 1) {
-                        itemList.add(CommonVariables.Page.reachBottom);
-                    } else {
-                        if (itemList.size() > 0) {
-                            itemList.add(CommonVariables.Page.reachBottom);
-                        } else {
-                            itemList.add(CommonVariables.Page.noMorePage);
-                        }
-                    }
-                }
-                cn.com.basic.face.fragment.VisitFragment.getInstance().get_fragment_visit_left_list_view().show(itemList, append);
-            }
-        });
+            });
+        } else {
+            findLeftVisitorListAfterReturn(VisitDao.getInstance().findLeftVisitorList(searchText,pageNum), append);
+        }
+    }
 
+    public void findLeftVisitorListAfterReturn(ResultBean resultBean, final boolean append) {
+        List<VisitQueryItem> list = resultBean.getList(VisitQueryItem.class);
+        final List itemList = new ArrayList();
+        int i = 0;
+        String previewDate = "";
+        SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");
+        SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy骞碝M鏈坉d鏃�");
+        if (append) {
+            List prevList = cn.com.basic.face.fragment.VisitFragment.getInstance().get_fragment_visit_left_list_view().getPrevList();
+            if (prevList != null && prevList.size() > 1) {
+                VisitQueryItem lastItem = (VisitQueryItem)prevList.get(prevList.size()-2);
+                try {
+                    previewDate = sdf2.format(sdf1.parse(lastItem.getEnterTime()));
+                } catch (Exception e) { }
+            }
+        }
+        for (VisitQueryItem item : list) {
+            try {
+                String yearMonthDay = sdf2.format(sdf1.parse(item.getEnterTime()));
+                if (!previewDate.equals(yearMonthDay)) {
+                    itemList.add(yearMonthDay);
+                    previewDate = yearMonthDay;
+                }
+            } catch (Exception e) { }
+            itemList.add(item);
+            i++;
+        }
+        addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList);
+        if (BaseApplication.getInstance().networkAvailable()) {
+            cn.com.basic.face.fragment.VisitFragment.getInstance().get_fragment_visit_left_list_view().show(itemList, append);
+        } else {
+            MainActivity.getInstance().runOnUiThread(new Runnable() {
+                @Override
+                public void run() {
+                    cn.com.basic.face.fragment.VisitFragment.getInstance().get_fragment_visit_left_list_view().show(itemList, append);
+                }
+            });
+        }
+    }
+
+    public void removeLastMonthData() {
+        try {
+            String sql = "delete from visit where 1=1 and enter_time< '" + DateUtil.getPreviousMonthLastDay() + "'";
+            MainActivity.getInstance().db.execSQL(sql);
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
     }
 
 }

--
Gitblit v1.8.0