From d6119c2d7fe2f802dd224d77bf2d95eeeedb4526 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期一, 10 七月 2017 16:08:15 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java | 152 +++++++++++++++++++++++++++++++++----------------- 1 files changed, 100 insertions(+), 52 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 9cf5964..7fb2382 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,13 +1,20 @@ package cn.com.basic.face.fragment; -import android.graphics.ImageFormat; -import android.media.ImageReader; +import android.content.Context; +import android.net.wifi.WifiManager; import android.os.Build; import android.os.Bundle; +import android.os.Environment; +import android.os.SystemClock; +import android.text.format.Formatter; +import android.util.Log; +import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; +import android.widget.ProgressBar; import android.widget.RadioButton; import android.widget.RadioGroup; +import android.widget.RelativeLayout; import android.widget.TextView; import com.bsk.zhangbo.demoforbsk.R; @@ -15,6 +22,7 @@ import cn.com.basic.face.base.BaseFragment; import cn.com.basic.face.base.MainActivity; +import cn.com.basic.face.discern.common.CommonVariables; import cn.com.basic.face.service.DeviceMng; import cn.com.basic.face.util.RtspFaceNative; @@ -22,11 +30,18 @@ import cn.com.basic.face.widget.surveilance.SurveillanceBottomAttendanceListView; import cn.com.basic.face.widget.surveilance.SurveillanceBottomVisitorListView; +import com.facebook.common.file.FileUtils; import com.lidroid.xutils.view.annotation.ViewInject; import com.lidroid.xutils.view.annotation.event.OnClick; -import java.text.SimpleDateFormat; -import java.util.Date; +import java.io.BufferedReader; +import java.io.DataOutputStream; +import java.io.File; +import java.io.FileReader; +import java.net.InetAddress; +import java.net.NetworkInterface; +import java.net.SocketException; +import java.util.*; public class SurveillanceFragment extends BaseFragment { @@ -43,13 +58,17 @@ @ViewInject(R.id.fragment_supervisory_bottom_attendance_list_view) private SurveillanceBottomAttendanceListView fragment_supervisory_bottom_attendance_list_view; @ViewInject(R.id.fragment_supervisory_enter_camera) - SurfaceView fragment_supervisory_enter_camera; + private SurfaceView fragment_supervisory_enter_camera; @ViewInject(R.id.fragment_supervisory_exit_camera) - SurfaceView fragment_supervisory_exit_camera; + private 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; + @ViewInject(R.id.fragment_supervisory_exit_camera_relative_layout) + private RelativeLayout fragment_supervisory_exit_camera_relative_layout; + @ViewInject(R.id.fragment_supervisory_enter_camera_relative_layout) + private RelativeLayout fragment_supervisory_enter_camera_relative_layout; static boolean useNative = false; @@ -70,6 +89,10 @@ } else { useNative = true; } + if (CommonVariables.FACE_SERVER) { + useNative = false; + } + //useNative = false; if (useNative) { System.loadLibrary("cvface_api"); System.loadLibrary("opencv_java3"); @@ -78,9 +101,47 @@ 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"); + WifiManager wm = (WifiManager) MainActivity.getInstance().getSystemService(Context.WIFI_SERVICE); + String ip = Formatter.formatIpAddress(wm.getConnectionInfo().getIpAddress()); + String ipAddress = null; + try { + for (Enumeration<NetworkInterface> en = NetworkInterface.getNetworkInterfaces(); en.hasMoreElements();) { + NetworkInterface intf = en.nextElement(); + for (Enumeration<InetAddress> enumIpAddr = intf.getInetAddresses(); enumIpAddr.hasMoreElements();) { + InetAddress inetAddress = enumIpAddr.nextElement(); + if (!inetAddress.isLoopbackAddress()) { + String ip1 = inetAddress.getHostAddress().toString(); + if (ip1.contains("192.")) { + ipAddress = ip1; + } + } + } + } + } catch (SocketException ex) {} + + try{ + //Process su = Runtime.getRuntime().exec("su"); + //DataOutputStream outputStream = new DataOutputStream(su.getOutputStream()); + + //outputStream.writeBytes("busybox ifconfig wlan0 down\n"); + //outputStream.flush(); + //Thread.sleep(5000); +// outputStream.writeBytes("busybox ifconfig wlan0 hw ether f4:8b:32:62:4f:89\n"); +// outputStream.flush(); + + //outputStream.writeBytes("exit\n"); + //outputStream.flush(); + //su.waitFor(); + /* + busybox ifconfig wlan0 hw ether AC:83:F3:42:19:CE + + + */ + }catch(Exception e){ + e.printStackTrace(); + } +// outputStream.writeBytes("busybox ifconfig wlan0 hw ether 00:e0:2c:31:1a:ba\n"); + RtspFaceNative.setLocalIP(ipAddress); } } @@ -105,45 +166,39 @@ @Override protected void initViews(View view, Bundle savedInstanceState) { - new Thread(new Runnable() { - @Override - public void run() { - try { - if (useNative) { - 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"); - } - }); + if (CommonVariables.FACE_SERVER) { + fragment_supervisory_enter_camera_relative_layout.addView(MainActivity.getInstance().mPreview); + fragment_supervisory_enter_camera_relative_layout.addView(MainActivity.getInstance().mDraw); - } 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(); + } + fragment_supervisory_enter_camera.getHolder().addCallback(new SurfaceHolder.Callback() { + public void surfaceCreated(SurfaceHolder holder) { + if (useNative) { + RtspFaceNative.setSurface(Integer.parseInt(CommonVariables.Camera.IN), fragment_supervisory_enter_camera.getHolder().getSurface()); + RtspFaceNative.createPlayer(Integer.parseInt(CommonVariables.Camera.IN), DeviceMng.getInstance().getCamera1Address()); + RtspFaceNative.setFaceCallback(Integer.parseInt(CommonVariables.Camera.IN), "cn/com/basic/face/util/RtspFaceNative", "faceCallBack"); } } - }).start(); - reloadBottomList(); + + public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {} + public void surfaceDestroyed(SurfaceHolder holder) { + System.out.println("surfaceDestroyed"); + } + }); + fragment_supervisory_exit_camera.getHolder().addCallback(new SurfaceHolder.Callback() { + public void surfaceCreated(SurfaceHolder holder) { + if (useNative) { + RtspFaceNative.setSurface(Integer.parseInt(CommonVariables.Camera.OUT), fragment_supervisory_exit_camera.getHolder().getSurface()); + RtspFaceNative.createPlayer(Integer.parseInt(CommonVariables.Camera.OUT), DeviceMng.getInstance().getCamera2Address()); + RtspFaceNative.setFaceCallback(Integer.parseInt(CommonVariables.Camera.OUT), "cn/com/basic/face/util/RtspFaceNative", "faceCallBack"); + } + } + + public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {} + public void surfaceDestroyed(SurfaceHolder holder) { + System.out.println("surfaceDestroyed"); + } + }); new SurveillanceMng.SurveillanceListThread().start(); } @@ -153,7 +208,6 @@ 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) @@ -162,7 +216,6 @@ 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 @@ -183,12 +236,7 @@ public void setMenuVisibility(boolean menuVisible) { super.setMenuVisibility(menuVisible); if (menuVisible && fragment_supervisory_bottom_visit_list_view != null) { - //reloadBottomList(); } - } - - private void reloadBottomList() { - SurveillanceMng.getInstance().findSurveillanceBottomList(fragment_supervisory_bottom_visitor_radio_button.isChecked()); } } -- Gitblit v1.8.0