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/AttendanceMng.java |  132 ++++++++++++++++++++++++++++----------------
 1 files changed, 84 insertions(+), 48 deletions(-)

diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
index c26ba13..8c1811f 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
@@ -5,11 +5,14 @@
 
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
+import java.util.Date;
 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.AttendanceDetailQueryCondition;
 import cn.com.basic.face.discern.query.condition.AttendanceQueryCondition;
 import cn.com.basic.face.discern.query.item.AttendanceDetailQueryItem;
@@ -30,63 +33,96 @@
         if (!BaseApplication.deviceAvailable) {
             return;
         }
-        RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.ATTENDANCE_QUERY);
-        params.addBodyParameter(AttendanceQueryCondition.FieldNames.username, searchText);
-        params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+"");
-        params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE);
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                List<AttendanceQueryItem> list = getList(AttendanceQueryItem.class);
-                List itemList = new ArrayList();
-                int i = 0;
-                String previewDate = "";
-                if (append) {
-                    List prevList = AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().getPrevList();
-                    if (prevList != null && prevList.size() > 1) {
-                        previewDate = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(
-                                ((AttendanceQueryItem)prevList.get(prevList.size()-2)).getTime());
-                    }
+        if(BaseApplication.getInstance().networkAvailable()) {
+            RequestParams params = new RequestParams(AppApi.BASE_URL + AppApi.Query.ATTENDANCE_QUERY);
+            params.addBodyParameter(AttendanceQueryCondition.FieldNames.username, searchText);
+            params.addBodyParameter(AttendanceQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+            params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum + "");
+            params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE);
+            x.http().post(params, new BaseCommonCallBack() {
+                public void success() {
+                    reloadLeftListAfterReturn(append, resultBean);
                 }
-                for (AttendanceQueryItem item : list) {
-                    try {
-                        String yyyyMMdd = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(item.getTime());
-                        if (!previewDate.equals(yyyyMMdd)) {
-                            itemList.add(yyyyMMdd);
-                            previewDate = yyyyMMdd;
-                        }
-                    } catch (Exception e) { }
-                    itemList.add(item);
-                    i++;
-                }
-                addPageFooter(hasMorePages(), getPageNum(), itemList);
-                AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append);
-            }
-        });
-
+            });
+        } else {
+            reloadLeftListAfterReturn(append, AttendanceDao.getInstance().reloadLeftList(searchText, pageNum, append));
+        }
     }
 
-    public void reloadAttendanceDetail(AttendanceQueryItem item) {
+    public void reloadLeftListAfterReturn(final boolean append, ResultBean resultBean) {
+        List<AttendanceQueryItem> list = resultBean.getList(AttendanceQueryItem.class);
+        final List itemList = new ArrayList();
+        int i = 0;
+        String previewDate = "";
+        if (append) {
+//                        List prevList = AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().getPrevList();
+//                        if (prevList != null && prevList.size() > 1) {
+//                            previewDate = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(
+//                                    ((AttendanceQueryItem) prevList.get(prevList.size() - 2)).getTime());
+//                        }
+        }
+        for (AttendanceQueryItem item : list) {
+//                        try {
+//                            String yyyyMMdd = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(item.getTime());
+//                            if (!previewDate.equals(yyyyMMdd)) {
+//                                itemList.add(yyyyMMdd);
+//                                previewDate = yyyyMMdd;
+//                            }
+//                        } catch (Exception e) {
+//                        }
+            itemList.add(item);
+            i++;
+        }
+        addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList);
+        if (BaseApplication.getInstance().networkAvailable()) {
+            AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append);
+        } else {
+            MainActivity.getInstance().runOnUiThread(new Runnable() {
+                @Override
+                public void run() {
+                    AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append);
+                }
+            });
+        }
+    }
+
+    public void reloadAttendanceDetail(final AttendanceQueryItem item) {
         if (!BaseApplication.deviceAvailable) {
             return;
         }
-        try {
-            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
-            RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.ATTENDANCE_DETAIL_QUERY);
-            params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.time, sdf.format(sdf.parse(item.getTime())));
-            params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.registerId, item.getRegisterId());
-            params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
-            params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "20");
-            x.http().post(params, new BaseCommonCallBack() {
-                public void success() {
-                    AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(getList(AttendanceDetailQueryItem.class));
+        if (BaseApplication.getInstance().networkAvailable()) {
+            try {
+                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+                RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.ATTENDANCE_DETAIL_QUERY);
+                params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.time, sdf.format(new Date()));
+                params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.registerId, item.getRegisterId());
+                params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+                params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "20");
+                x.http().post(params, new BaseCommonCallBack() {
+                    public void success() {
+                        AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(getList(AttendanceDetailQueryItem.class));
+                    }
+                });
+            } catch (Exception e) {
+                e.printStackTrace();
+            }
+        } else {
+            MainActivity.getInstance().runOnUiThread(new Runnable() {
+                @Override
+                public void run() {
+                    AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(AttendanceDao.getInstance().reloadAttendanceDetail(item));
                 }
             });
-        } catch (Exception e) {
-            e.printStackTrace();
-        }
-        if (1==1) {//娌$綉浜�
-            AttendanceDao.getInstance().reloadAttendanceDetail(item);
         }
     }
 
+    public void removeBeforeToday() {
+        try {
+            String sql = "delete from attendance where 1=1 and time< '" + DateUtil.getYesterday() + "'";
+            MainActivity.getInstance().db.execSQL(sql);
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+
+    }
 }

--
Gitblit v1.8.0