From 9a31f01e796d262c7fc3555a3ad42801e9b343a5 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期五, 31 三月 2017 13:45:47 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java | 125 +++++++++++++++++++---------------------- 1 files changed, 58 insertions(+), 67 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..fc71781 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; /** @@ -39,25 +34,36 @@ 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_register_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 +73,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 +104,20 @@ 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; -// } + 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_visit_list_view.setVisibility(View.VISIBLE); + fragment_supervisory_bottom_attendance_list_view.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_visit_list_view.setVisibility(View.GONE); + fragment_supervisory_bottom_attendance_list_view.setVisibility(View.VISIBLE); + break; + } reloadBottomList(); } }); @@ -115,34 +126,14 @@ @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); - } + SupervisoryMng.getInstance().findSupervisoryBottomList(fragment_supervisory_bottom_visitor_radio_button.isChecked()); } - 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); - } - } - } } -- Gitblit v1.8.0