From 2c0554e86d5b30200fab8cfeb985956c5275bc78 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期六, 01 四月 2017 14:04:45 +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 05b8b80..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.recyclerview_register);
- mRecyclerViewUser = (EasyRecyclerView) view.findViewById(R.id.recyclerview_user);
- 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