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

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java |  370 +++++++++-------------------------------------------
 1 files changed, 67 insertions(+), 303 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 d510248..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,31 +1,21 @@
 package cn.com.basic.face.fragment;
 
-import android.graphics.Rect;
-import android.graphics.SurfaceTexture;
 import android.os.Bundle;
-import android.support.v7.widget.GridLayoutManager;
-import android.support.v7.widget.LinearLayoutManager;
-import android.support.v7.widget.RecyclerView;
-import android.util.Log;
-import android.view.Surface;
-import android.view.SurfaceHolder;
-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.SupervisoryAdapter;
-import cn.com.basic.face.base.BaseFragment;
-import cn.com.basic.face.service.CheckInMng;
-import cn.com.basic.face.util.RtspFaceNative;
-import cn.com.basic.face.util.WindowsUtil;
-import cn.com.basic.face.widget.MyGLSurfaceView;
-import com.camnter.easyrecyclerview.widget.EasyRecyclerView;
-import com.orhanobut.logger.Logger;
 
-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;
 
 
 /**
@@ -34,41 +24,44 @@
 
 public class SupervisoryFragment extends BaseFragment {
 
-    private RadioGroup mRadioGroup;
-    private RadioButton mRadioButton1, mRadioButton2;
-    private View mRadioLine1, mRadioLine2;
-    private SupervisoryAdapter mAdapter;
-    private List mList;
-    private EasyRecyclerView mRecyclerViewRegister, mRecyclerViewUser;
+    @ViewInject(R.id.fragment_supervisory_bottom_left_radio_group)
+    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_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_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)
+    VideoView fragment_supervisory_enter_camera;
+    @ViewInject(R.id.fragment_supervisory_exit_camera)
+    VideoView fragment_supervisory_exit_camera;
 
-    //鎾斁
+    static boolean useNative = false;
 
-    String mSourceString = "clips/testfile.mp4";
-
-    SurfaceView mSurfaceView1;
-    SurfaceView mSurfaceView2;
-    SurfaceHolder mSurfaceHolder1;
-
-    VideoSink mSelectedVideoSink;
-
-
-    SurfaceHolderVideoSink mSurfaceHolder1VideoSink;
-
-    VideoSink mNativeCodecPlayerVideoSink;
-    GLViewVideoSink mGLView1VideoSink;
-    boolean mCreated = false;
-    boolean mIsPlaying = false;
-
-    /** Load jni .so on initialization */
     static {
-        //System.loadLibrary("rtspface");//xiuxi
+        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
@@ -78,285 +71,56 @@
 
     @Override
     protected void initViews(View view, Bundle savedInstanceState) {
-        mRadioGroup = (RadioGroup) view.findViewById(R.id.fragment_supervisory_bottom_left_radio_group);
-        mRadioButton1 = (RadioButton) view.findViewById(R.id.fragment_supervisory_bottom_visitor_radio_button);
-        mRadioButton2 = (RadioButton) view.findViewById(R.id.fragment_supervisory_bottom_attendance_radio_button);
-        mRadioLine1 = view.findViewById(R.id.fragment_supervisory_bottom_visitor_background);
-        mRadioLine2 = view.findViewById(R.id.fragment_supervisory_bottom_attendance_background);
-        mRecyclerViewRegister = (EasyRecyclerView) view.findViewById(R.id.fragment_supervisory_bottom_register_list);
-        mRecyclerViewUser = (EasyRecyclerView) view.findViewById(R.id.fragment_supervisory_bottom_visitor_list);
-        mRadioButton1.setChecked(true);
-        mRecyclerViewRegister.addItemDecoration(new SpaceItemDecoration());
-        GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), 2);
-        gridLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
-        mRecyclerViewRegister.setLayoutManager(gridLayoutManager);
-        mAdapter = new SupervisoryAdapter(getActivity());
-
-
-        mSurfaceView2 = (SurfaceView) view.findViewById(R.id.fragment_supervisory_exit_camera);
-        mSurfaceView1 = (SurfaceView) view.findViewById(R.id.fragment_supervisory_enter_camera);
-        RtspFaceNative.init();
-        RtspFaceNative.setSurface(1, mSurfaceView1.getHolder().getSurface());
-        RtspFaceNative.setSurface(2, mSurfaceView2.getHolder().getSurface());
-
-        mSurfaceHolder1 = mSurfaceView1.getHolder();
-
-        mSurfaceHolder1.addCallback(new SurfaceHolder.Callback() {
-
-            @Override
-            public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
-                Logger.e( "surfaceChanged format=" + format + ", width=" + width + ", height="
-                        + height);
-            }
-
-            @Override
-            public void surfaceCreated(SurfaceHolder holder) {
-                Logger.e( "surfaceCreated");
-            }
-
-            @Override
-            public void surfaceDestroyed(SurfaceHolder holder) {
-                Logger.e( "surfaceDestroyed");
-            }
-
-        });
-        //surfaceview
-        if (mSurfaceHolder1VideoSink == null) {
-            mSurfaceHolder1VideoSink = new SurfaceHolderVideoSink(mSurfaceHolder1);
-        }
-        mSelectedVideoSink = mSurfaceHolder1VideoSink;
-
-
-        //openGL
-        if(mSurfaceView2 instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView)mSurfaceView2).onResume();
-        }
-        if (mGLView1VideoSink == null) {
-            mGLView1VideoSink = new GLViewVideoSink(mSurfaceView2);
-        }
-        mSelectedVideoSink = mGLView1VideoSink;
-
-
-        //鎾斁寤惰繜锛堝垵濮嬪寲杈冩參锛屽彲鑳藉鑷存棤娉曟甯告挱鏀撅級
-        Thread thread = new Thread(new Runnable() {
+        new Thread(new Runnable() {
             @Override
             public void run() {
                 try {
-                    Thread.sleep(5000);
-                    if (!mCreated) {
-                        if (mNativeCodecPlayerVideoSink == null) {
-                            if (mSelectedVideoSink == null) {
-                                return;
-                            }
-                            mSelectedVideoSink.useAsSinkForNative();
-                            mSurfaceHolder1VideoSink.useAsSinkForNative();
-                            //mSelectedVideoSink.useAsSinkForNative();
-                            //mSurfaceHolder1VideoSink.useAsSinkForNative();
-                            mNativeCodecPlayerVideoSink = mSelectedVideoSink;
-                        }
-                        if (mSourceString != null) {
-                            //mCreated = createStreamingMediaPlayer(getResources().getAssets(),
-                            //        mSourceString);
-                            mCreated = RtspFaceNative.createPlayer(1, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
-                            mCreated = RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/sub/av_stream");
-                            ////mCreated = createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/main/av_stream");
-                        }
+                    Thread.sleep(2000);
+                    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();
                     }
-                    if (mCreated) {
-                        mIsPlaying = !mIsPlaying;
-                        //setPlayingStreamingMediaPlayer(mIsPlaying);
-                    }
-
-
-                } catch (InterruptedException e) {
+                } catch (Exception e) {
                     e.printStackTrace();
                 }
             }
-        });
-        thread.start();//xiuxi
+        }).start();
+        reloadBottomList();
     }
 
     @Override
     protected void initListeners() {
-        mRadioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
+        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:
-                        mRadioLine1.setVisibility(View.VISIBLE);
-                        mRadioLine2.setVisibility(View.INVISIBLE);
-                        mRecyclerViewRegister.setVisibility(View.VISIBLE);
-                        mRecyclerViewUser.setVisibility(View.GONE);
-                        break;
-                    case R.id.fragment_supervisory_bottom_attendance_radio_button:
-                        mRadioLine1.setVisibility(View.INVISIBLE);
-                        mRadioLine2.setVisibility(View.VISIBLE);
-                        mRecyclerViewRegister.setVisibility(View.GONE);
-                        mRecyclerViewUser.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();
             }
         });
     }
 
     @Override
-    protected void initData() {
-//        switchSurface();
-        mList = new ArrayList();
-//        for (int i = 0; i < 125; i++) {
-//            FacePhotoItem item = new FacePhotoItem();
-//            //item.setType();
-//            item.setName("寮犱笁"+i);
-//            if (i % 3 == 0) {
-//                item.setStatus("鏉ヨ鐧昏");
-//            } else {
-//                item.setStatus("绛剧");
-//            }
-//            if (i % 5 == 0) {
-//                item.setWarning("");
-//            } else {
-//                item.setWarning("璀﹀憡");
-//            }
-//            mList.add(item);
-//        }
-        CheckInMng.getInstance().findVisitorList();
-        mAdapter.setList(mList);
-        mRecyclerViewRegister.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.bottom = WindowsUtil.dip2px(getActivity(), 7);
-            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);
-            }
+    public void setMenuVisibility(boolean menuVisible) {
+        super.setMenuVisibility(menuVisible);
+        if (menuVisible && fragment_supervisory_bottom_visit_list_view != null) {
+            reloadBottomList();
         }
     }
 
-    void switchSurface() {
-        if (mCreated && mNativeCodecPlayerVideoSink != mSelectedVideoSink) {
-            // shutdown and recreate on other surface
-            Log.i("@@@", "shutting down player");
-            RtspFaceNative.shutdown(1);
-            mCreated = false;
-            mSelectedVideoSink.useAsSinkForNative();
-            mNativeCodecPlayerVideoSink = mSelectedVideoSink;
-            if (mSourceString != null) {
-                Log.i("@@@", "recreating player");
-                //mCreated = createStreamingMediaPlayer(getResources().getAssets(), mSourceString);
-                mIsPlaying = false;
-                mCreated = RtspFaceNative.createPlayer(1, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/main/av_stream");
-                mCreated = RtspFaceNative.createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/main/av_stream");
-                ////mCreated = createPlayer(2, "rtsp://admin:admin12345@192.168.1.70:554/h264/ch1/main/av_stream");
-            }
-        }
+    private void reloadBottomList() {
+        SupervisoryMng.getInstance().findSupervisoryBottomList(fragment_supervisory_bottom_visitor_radio_button.isChecked());
     }
 
-    /**
-     * Called when the activity is about to be paused.
-     */
-    @Override
-    public void onPause() {
-        mIsPlaying = false;
-        if(mSurfaceView2 instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView)mSurfaceView2).onPause();
-        }
-        //setPlayingStreamingMediaPlayer(false);//xiuxi
-        super.onPause();
-    }
-
-    @Override
-    public void onResume() {
-        super.onResume();
-        if(mSurfaceView2 instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView)mSurfaceView2).onResume();
-        }
-    }
-
-    /**
-     * Called when the activity is about to be destroyed.
-     */
-    @Override
-    public void onDestroy() {
-        RtspFaceNative.shutdown(1);
-        mCreated = false;
-        super.onDestroy();
-    }
-
-
-    // VideoSink abstracts out the difference between Surface and SurfaceTexture
-    // aka SurfaceHolder and GLSurfaceView
-    static abstract class VideoSink {
-
-        abstract void setFixedSize(int width, int height);
-
-        abstract void useAsSinkForNative();
-
-    }
-
-    static class SurfaceHolderVideoSink extends VideoSink {
-
-        private final SurfaceHolder mSurfaceHolder;
-
-        SurfaceHolderVideoSink(SurfaceHolder surfaceHolder) {
-            mSurfaceHolder = surfaceHolder;
-        }
-
-        @Override
-        void setFixedSize(int width, int height) {
-            mSurfaceHolder.setFixedSize(width, height);
-        }
-
-        @Override
-        void useAsSinkForNative() {
-            Surface s = mSurfaceHolder.getSurface();
-            Log.i("@@@", "setting surface " + s);
-            RtspFaceNative.setSurface(1, s);
-
-
-            /*SurfaceTexture st = mSurfaceHolder.getSurfaceTexture();
-            Surface s = new Surface(st);
-            RtspFaceNative.setSurface(2, s);
-            s.release();*/
-        }
-
-    }
-
-
-    static class GLViewVideoSink extends VideoSink {
-
-        private final SurfaceView SurfaceView;
-        private final SurfaceHolder mSurfaceHolder;
-
-        GLViewVideoSink(SurfaceView myGLSurfaceView) {
-            SurfaceView = myGLSurfaceView;
-            mSurfaceHolder = SurfaceView.getHolder();
-        }
-
-        @Override
-        void setFixedSize(int width, int height) {
-            mSurfaceHolder.setFixedSize(width, height);
-        }
-
-        @Override
-        void useAsSinkForNative() {
-            if(SurfaceView instanceof MyGLSurfaceView) {
-                SurfaceTexture st = ((MyGLSurfaceView)SurfaceView).getSurfaceTexture();
-                Surface s = new Surface(st);
-                RtspFaceNative.setSurface(2, s);
-                s.release();
-            } else {
-                RtspFaceNative.setSurface(2, SurfaceView.getHolder().getSurface());
-            }
-
-        }
-
-    }
 }

--
Gitblit v1.8.0