From 72d0e1491aee41558f4c20df0f622d9a334e8010 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期五, 31 三月 2017 15:24:36 +0800
Subject: [PATCH] 

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java |  118 ++++++++++++++++++++++++-----------------------------------
 1 files changed, 48 insertions(+), 70 deletions(-)

diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java
index 86373a3..9e4042b 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java
@@ -1,26 +1,21 @@
 package cn.com.basic.face.fragment;
 
-import android.graphics.Rect;
 import android.os.Bundle;
-import android.support.v7.widget.GridLayoutManager;
-import android.support.v7.widget.LinearLayoutManager;
-import android.support.v7.widget.RecyclerView;
-import android.view.SurfaceView;
 import android.view.View;
 import android.widget.RadioButton;
 import android.widget.RadioGroup;
+import android.widget.VideoView;
 
 import com.bsk.zhangbo.demoforbsk.R;
-import cn.com.basic.face.adapter.SupervisoryBottomAdapter;
-import cn.com.basic.face.base.BaseFragment;
-import cn.com.basic.face.service.CheckInMng;
-import com.bsk.zhangbo.demoforbsk.util.RtspFaceNative;
-import cn.com.basic.face.util.WindowsUtil;
-import com.camnter.easyrecyclerview.widget.EasyRecyclerView;
-import com.lidroid.xutils.view.annotation.ViewInject;
 
-import java.util.ArrayList;
-import java.util.List;
+import cn.com.basic.face.base.BaseFragment;
+
+import com.bsk.zhangbo.demoforbsk.util.RtspFaceNative;
+
+import cn.com.basic.face.service.SupervisoryMng;
+import cn.com.basic.face.widget.SupervisoryBottomListView;
+
+import com.lidroid.xutils.view.annotation.ViewInject;
 
 
 /**
@@ -33,31 +28,40 @@
     private RadioGroup fragment_supervisory_bottom_left_radio_group;
     @ViewInject(R.id.fragment_supervisory_bottom_visitor_radio_button)
     private RadioButton fragment_supervisory_bottom_visitor_radio_button;
-    @ViewInject(R.id.fragment_supervisory_bottom_attendance_radio_button)
-    private RadioButton fragment_supervisory_bottom_attendance_radio_button;
     @ViewInject(R.id.fragment_supervisory_bottom_visitor_background)
     private View fragment_supervisory_bottom_visitor_background;
     @ViewInject(R.id.fragment_supervisory_bottom_attendance_background)
     private View fragment_supervisory_bottom_attendance_background;
-    @ViewInject(R.id.fragment_supervisory_bottom_register_list)
-    private EasyRecyclerView fragment_supervisory_bottom_register_list;
+    @ViewInject(R.id.fragment_supervisory_bottom_visit_list_view)
+    private SupervisoryBottomListView fragment_supervisory_bottom_visit_list_view;
+    @ViewInject(R.id.fragment_supervisory_bottom_attendance_list_view)
+    private SupervisoryBottomListView fragment_supervisory_bottom_attendance_list_view;
     @ViewInject(R.id.fragment_supervisory_enter_camera)
-    SurfaceView fragment_supervisory_enter_camera;
+    VideoView fragment_supervisory_enter_camera;
     @ViewInject(R.id.fragment_supervisory_exit_camera)
-    SurfaceView fragment_supervisory_exit_camera;
+    VideoView fragment_supervisory_exit_camera;
 
-    private SupervisoryBottomAdapter mAdapter;
-    private List mList;
+    static boolean useNative = false;
 
     static {
-        System.loadLibrary("rtspface");
-        RtspFaceNative.init();
+        if (useNative) {
+            System.loadLibrary("rtspface");
+            RtspFaceNative.init();
+        }
     }
 
     private static SupervisoryFragment instance = new SupervisoryFragment();
 
     public static SupervisoryFragment getInstance() {
         return instance;
+    }
+
+    public SupervisoryBottomListView get_fragment_supervisory_bottom_visit_list_view() {
+        return fragment_supervisory_bottom_visit_list_view;
+    }
+
+    public SupervisoryBottomListView get_fragment_supervisory_bottom_attendance_list_view() {
+        return fragment_supervisory_bottom_visit_list_view;
     }
 
     @Override
@@ -67,25 +71,30 @@
 
     @Override
     protected void initViews(View view, Bundle savedInstanceState) {
-        fragment_supervisory_bottom_register_list.addItemDecoration(new SpaceItemDecoration());
-        GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), 2);
-        gridLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
-        fragment_supervisory_bottom_register_list.setLayoutManager(gridLayoutManager);
-        mAdapter = new SupervisoryBottomAdapter(getActivity());
         new Thread(new Runnable() {
             @Override
             public void run() {
                 try {
                     Thread.sleep(2000);
-                    RtspFaceNative.setSurface(1, fragment_supervisory_enter_camera.getHolder().getSurface());
-                    RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface());
-                    RtspFaceNative.createPlayer(1, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
-                    RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
+                    if (useNative) {
+                        RtspFaceNative.setSurface(1, fragment_supervisory_enter_camera.getHolder().getSurface());
+                        RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface());
+                        RtspFaceNative.createPlayer(1, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
+                        RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
+                    } else {
+//                        fragment_supervisory_enter_camera.setVideoURI(Uri.parse("rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream"));
+//                        fragment_supervisory_enter_camera.requestFocus();
+//                        fragment_supervisory_enter_camera.start();
+//                        fragment_supervisory_exit_camera.setVideoURI(Uri.parse("rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/main/av_stream"));
+//                        fragment_supervisory_exit_camera.requestFocus();
+//                        fragment_supervisory_exit_camera.start();
+                    }
                 } catch (Exception e) {
                     e.printStackTrace();
                 }
             }
         }).start();
+        reloadBottomList();
     }
 
     @Override
@@ -93,20 +102,10 @@
         fragment_supervisory_bottom_left_radio_group.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
             @Override
             public void onCheckedChanged(RadioGroup group, int checkedId) {
-//                switch (checkedId) {
-//                    case R.id.fragment_supervisory_bottom_visitor_radio_button:
-//                        fragment_supervisory_bottom_visitor_background.setVisibility(View.VISIBLE);
-//                        fragment_supervisory_bottom_attendance_background.setVisibility(View.INVISIBLE);
-//                        fragment_supervisory_bottom_register_list.setVisibility(View.VISIBLE);
-//                        fragment_supervisory_bottom_visitor_list.setVisibility(View.GONE);
-//                        break;
-//                    case R.id.fragment_supervisory_bottom_attendance_radio_button:
-//                        fragment_supervisory_bottom_visitor_background.setVisibility(View.INVISIBLE);
-//                        fragment_supervisory_bottom_attendance_background.setVisibility(View.VISIBLE);
-//                        fragment_supervisory_bottom_register_list.setVisibility(View.GONE);
-//                        fragment_supervisory_bottom_visitor_list.setVisibility(View.VISIBLE);
-//                        break;
-//                }
+                fragment_supervisory_bottom_visitor_background.setVisibility(fragment_supervisory_bottom_visitor_radio_button.isChecked()?View.VISIBLE:View.GONE);
+                fragment_supervisory_bottom_visit_list_view.setVisibility(fragment_supervisory_bottom_visitor_radio_button.isChecked()?View.VISIBLE:View.GONE);
+                fragment_supervisory_bottom_attendance_background.setVisibility(!fragment_supervisory_bottom_visitor_radio_button.isChecked()?View.VISIBLE:View.GONE);
+                fragment_supervisory_bottom_attendance_list_view.setVisibility(!fragment_supervisory_bottom_visitor_radio_button.isChecked()?View.VISIBLE:View.GONE);
                 reloadBottomList();
             }
         });
@@ -115,34 +114,13 @@
     @Override
     public void setMenuVisibility(boolean menuVisible) {
         super.setMenuVisibility(menuVisible);
-        if (menuVisible) {
+        if (menuVisible && fragment_supervisory_bottom_visit_list_view != null) {
             reloadBottomList();
         }
     }
 
     private void reloadBottomList() {
-        if (fragment_supervisory_bottom_register_list != null) {
-            mList = new ArrayList();
-            CheckInMng.getInstance().findVisitorList();
-            mAdapter = new SupervisoryBottomAdapter(getActivity());
-            mAdapter.setList(mList);
-            fragment_supervisory_bottom_register_list.setAdapter(mAdapter);
-        }
-    }
-
-    private class SpaceItemDecoration extends RecyclerView.ItemDecoration {
-        @Override
-        public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
-            super.getItemOffsets(outRect, view, parent, state);
-            outRect.right = WindowsUtil.dip2px(getActivity(), 15);
-
-            if (parent.getChildLayoutPosition(view) == 0 || parent.getChildLayoutPosition(view) == 1) {
-                outRect.left = WindowsUtil.dip2px(getActivity(), 14);
-            }
-            if (parent.getChildLayoutPosition(view) % 2 == 0) {
-                outRect.bottom = WindowsUtil.dip2px(getActivity(), 7);
-            }
-        }
+        SupervisoryMng.getInstance().findSupervisoryBottomList(fragment_supervisory_bottom_visitor_radio_button.isChecked());
     }
 
 }

--
Gitblit v1.8.0