From 75caa65bc18cb12b1b314a0641e01da962337359 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期五, 12 五月 2017 15:23:45 +0800
Subject: [PATCH] 

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SurveillanceFragment.java |   91 +++++++++++++++++++++++++++++++++++++--------
 1 files changed, 75 insertions(+), 16 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 2acccc6..e42172e 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,6 +1,10 @@
 package cn.com.basic.face.fragment;
 
+import android.content.Context;
+import android.net.wifi.WifiManager;
+import android.os.Build;
 import android.os.Bundle;
+import android.text.format.Formatter;
 import android.view.SurfaceView;
 import android.view.View;
 import android.widget.RadioButton;
@@ -12,17 +16,24 @@
 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.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.io.BufferedReader;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileReader;
+import java.io.InputStream;
+import java.io.InputStreamReader;
 import java.text.SimpleDateFormat;
-import java.util.Date;
 
 public class SurveillanceFragment extends BaseFragment {
 
@@ -47,9 +58,25 @@
     @ViewInject(R.id.fragment_surveillance_exit_timer)
     private TextView fragment_surveillance_exit_timer;
 
-    static boolean useNative = true;
+    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");
@@ -58,7 +85,13 @@
             System.loadLibrary("protoc");
             System.loadLibrary("rtspface");
             RtspFaceNative.init();
-            RtspFaceNative.setLocalIP("192.168.1.10");
+//            RtspFaceNative.setLocalIP("192.168.1.10");
+//            RtspFaceNative.setLocalIP("192.168.1.106");//鑷繁鎵嬫満ip
+//            RtspFaceNative.setLocalIP("192.168.1.203");
+//            RtspFaceNative.setLocalIP("192.168.1.205");
+            WifiManager wm = (WifiManager) MainActivity.getInstance().getSystemService(Context.WIFI_SERVICE);
+            String ip = Formatter.formatIpAddress(wm.getConnectionInfo().getIpAddress());
+            RtspFaceNative.setLocalIP(ip);
         }
     }
 
@@ -90,12 +123,36 @@
                     if (useNative) {
                         MainActivity.getInstance().runOnUiThread(new Runnable() {
                             public void run() {
+                                try {
+                                    String str = convertStreamToString(MainActivity.getInstance().getAssets().open("license.lic"));
+                                    RtspFaceNative.dbgSetStfaceLicense(str);
+                                } catch (Exception e) {
+                                    e.printStackTrace();
+                                }
                                 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:a1234567@192.168.1.68:554/h264/ch1/sub/av_stream");
+                                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");
+                            }
+                            public String convertStreamToString(InputStream is) throws Exception {
+                                BufferedReader reader = new BufferedReader(new InputStreamReader(is));
+                                StringBuilder sb = new StringBuilder();
+                                String line = null;
+                                while ((line = reader.readLine()) != null) {
+                                    sb.append(line).append("\n");
+                                }
+                                reader.close();
+                                return sb.toString();
+                            }
+                            public String getStringFromFile (String filePath) throws Exception {
+                                File fl = new File(filePath);
+                                FileInputStream fin = new FileInputStream(fl);
+                                String ret = convertStreamToString(fin);
+                                //Make sure you close all streams.
+                                fin.close();
+                                return ret;
                             }
                         });
 
@@ -106,21 +163,23 @@
                 }
                 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 (InterruptedException e) {
+//                    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)

--
Gitblit v1.8.0