From 109ffe9a777658936a38d0c146579a67c60a0d17 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 11 五月 2017 17:48:48 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java | 115 +++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 94 insertions(+), 21 deletions(-) diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java index 1b90897..9cf5964 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java @@ -1,21 +1,32 @@ package cn.com.basic.face.fragment; +import android.graphics.ImageFormat; +import android.media.ImageReader; +import android.os.Build; import android.os.Bundle; +import android.view.SurfaceView; import android.view.View; import android.widget.RadioButton; import android.widget.RadioGroup; -import android.widget.VideoView; +import android.widget.TextView; import com.bsk.zhangbo.demoforbsk.R; import cn.com.basic.face.base.BaseFragment; +import cn.com.basic.face.base.MainActivity; +import cn.com.basic.face.service.DeviceMng; import cn.com.basic.face.util.RtspFaceNative; import cn.com.basic.face.service.SurveillanceMng; -import cn.com.basic.face.widget.surveilance.SurveillanceBottomListView; +import cn.com.basic.face.widget.surveilance.SurveillanceBottomAttendanceListView; +import cn.com.basic.face.widget.surveilance.SurveillanceBottomVisitorListView; import com.lidroid.xutils.view.annotation.ViewInject; +import com.lidroid.xutils.view.annotation.event.OnClick; + +import java.text.SimpleDateFormat; +import java.util.Date; public class SurveillanceFragment extends BaseFragment { @@ -28,17 +39,37 @@ @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 SurveillanceBottomListView fragment_supervisory_bottom_visit_list_view; + private SurveillanceBottomVisitorListView fragment_supervisory_bottom_visit_list_view; @ViewInject(R.id.fragment_supervisory_bottom_attendance_list_view) - private SurveillanceBottomListView fragment_supervisory_bottom_attendance_list_view; + private SurveillanceBottomAttendanceListView fragment_supervisory_bottom_attendance_list_view; @ViewInject(R.id.fragment_supervisory_enter_camera) - VideoView fragment_supervisory_enter_camera; + SurfaceView fragment_supervisory_enter_camera; @ViewInject(R.id.fragment_supervisory_exit_camera) - VideoView fragment_supervisory_exit_camera; + SurfaceView fragment_supervisory_exit_camera; + @ViewInject(R.id.fragment_surveillance_enter_timer) + private TextView fragment_surveillance_enter_timer; + @ViewInject(R.id.fragment_surveillance_exit_timer) + private TextView fragment_surveillance_exit_timer; static boolean useNative = false; + public static boolean isEmulator() { + return Build.FINGERPRINT.startsWith("generic") + || Build.FINGERPRINT.startsWith("unknown") + || Build.MODEL.contains("google_sdk") + || Build.MODEL.contains("Emulator") + || Build.MODEL.contains("Android SDK built for x86") + || Build.MANUFACTURER.contains("Genymotion") + || (Build.BRAND.startsWith("generic") && Build.DEVICE.startsWith("generic")) + || "google_sdk".equals(Build.PRODUCT); + } + static { + if (isEmulator()) { + useNative = false; + } else { + useNative = true; + } if (useNative) { System.loadLibrary("cvface_api"); System.loadLibrary("opencv_java3"); @@ -47,6 +78,9 @@ System.loadLibrary("protoc"); System.loadLibrary("rtspface"); RtspFaceNative.init(); +// RtspFaceNative.setLocalIP("192.168.1.10"); + RtspFaceNative.setLocalIP("192.168.1.106");//鑷繁鎵嬫満ip +// RtspFaceNative.setLocalIP("192.168.1.203"); } } @@ -56,12 +90,12 @@ return instance; } - public SurveillanceBottomListView get_fragment_supervisory_bottom_visit_list_view() { + public SurveillanceBottomVisitorListView get_fragment_supervisory_bottom_visitor_list_view() { return fragment_supervisory_bottom_visit_list_view; } - public SurveillanceBottomListView get_fragment_supervisory_bottom_attendance_list_view() { - return fragment_supervisory_bottom_visit_list_view; + public SurveillanceBottomAttendanceListView get_fragment_supervisory_bottom_attendance_list_view() { + return fragment_supervisory_bottom_attendance_list_view; } @Override @@ -75,20 +109,59 @@ @Override public void run() { try { - 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"); - RtspFaceNative.setFaceCallback(1, "cn/com/basic/face/util/RtspFaceNative", "faceCallBack"); + MainActivity.getInstance().runOnUiThread(new Runnable() { + public void run() { + RtspFaceNative.setSurface(1, fragment_supervisory_enter_camera.getHolder().getSurface()); + RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface()); + RtspFaceNative.createPlayer(1, DeviceMng.getInstance().getCamera1Address()); + RtspFaceNative.createPlayer(2, DeviceMng.getInstance().getCamera2Address()); + RtspFaceNative.setFaceCallback(1, "cn/com/basic/face/util/RtspFaceNative", "faceCallBack"); + RtspFaceNative.setFaceCallback(2, "cn/com/basic/face/util/RtspFaceNative", "faceCallBack"); + } + }); + } else { } } catch (Exception e) { e.printStackTrace(); } + try { + final SimpleDateFormat sdf = new SimpleDateFormat("yyyy骞碝M鏈坉d鏃� HH锛歮m锛歴s鍒�"); +// while (true) { +// Thread.sleep(1000); +// MainActivity.getInstance().runOnUiThread(new Runnable() { +// @Override +// public void run() { +// fragment_surveillance_enter_timer.setText(sdf.format(new Date())); +// fragment_surveillance_exit_timer.setText(sdf.format(new Date())); +// } +// }); +// } + } catch (Exception e) { + e.printStackTrace(); + } } }).start(); + reloadBottomList(); + new SurveillanceMng.SurveillanceListThread().start(); + } + + @OnClick(R.id.fragment_supervisory_bottom_visitor_radio_button) + public void fragment_supervisory_bottom_visitor_radio_button_click(View view) { + 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(); + } + + @OnClick(R.id.fragment_supervisory_bottom_attendance_radio_button) + public void fragment_supervisory_bottom_attendance_radio_button_click(View view) { + 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(); } @@ -97,11 +170,11 @@ fragment_supervisory_bottom_left_radio_group.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { - 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(); +// 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(); } }); } @@ -110,7 +183,7 @@ public void setMenuVisibility(boolean menuVisible) { super.setMenuVisibility(menuVisible); if (menuVisible && fragment_supervisory_bottom_visit_list_view != null) { - reloadBottomList(); + //reloadBottomList(); } } -- Gitblit v1.8.0