From 59ec75d7d8cdacfae7b0f157993cd217743ae563 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期四, 30 三月 2017 16:47:14 +0800
Subject: [PATCH] 

---
 /dev/null                                                                                      |   33 ----
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/base/BaseApplication.java             |    2 
 VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java     |   33 ++++
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/fragment/SupervisoryFragment.java     |  299 ++++++------------------------------------
 VisitFace/DemoForBsk/app/src/main/res/layout/fragment_supervisory.xml                          |    4 
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryBottomAdapter.java |   12 -
 6 files changed, 82 insertions(+), 301 deletions(-)

diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryAdapter.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryBottomAdapter.java
similarity index 93%
rename from VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryAdapter.java
rename to VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryBottomAdapter.java
index 63d1ab2..70a00d9 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryAdapter.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/SupervisoryBottomAdapter.java
@@ -26,12 +26,12 @@
  * Created by zhangbo on 2017/2/15.
  */
 
-public class SupervisoryAdapter extends EasyRecyclerViewAdapter {
+public class SupervisoryBottomAdapter extends EasyRecyclerViewAdapter {
     private int TYPE_1 = 0,TYPE_2 = 1;
     private int type;
     private Context context;
     private List list;
-    public SupervisoryAdapter(Context context) {
+    public SupervisoryBottomAdapter(Context context) {
         this.context = context;
     }
 
@@ -45,7 +45,6 @@
         int recycleViewItemType = getRecycleViewItemType(position);
         switch (recycleViewItemType){
             case 0:
-
                 RegisterViewHolder(viewHolder,position);
                 break;
             case 1:
@@ -97,7 +96,6 @@
             });
         }
     }
-
 
     /**
      * 绗簩鍒楃敤鎴锋儏鍐�
@@ -169,11 +167,5 @@
             }
         }
 
-
-//        ImageView mSdv = holder.findViewById(R.id.item_user_bcg);
-//        ViewGroup.LayoutParams mSdvLayoutParams = mSdv.getLayoutParams();
-//        mSdvLayoutParams.height = WindowsUtil.dip2px(context, 60);
-//        mSdvLayoutParams.width = WindowsUtil.dip2px(context, 60);
-//        mSdv.setLayoutParams(mSdvLayoutParams);
     }
 }
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/base/BaseApplication.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/base/BaseApplication.java
index 9dbf51d..1c5629f 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/base/BaseApplication.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/base/BaseApplication.java
@@ -5,6 +5,8 @@
 import cn.com.basic.face.service.DictionaryMng;
 import cn.com.basic.face.service.PlaceMng;
 import cn.com.basic.face.service.VisitorTypeMng;
+
+import com.bsk.zhangbo.demoforbsk.util.RtspFaceNative;
 import com.facebook.drawee.backends.pipeline.Fresco;
 import com.lzy.okhttputils.OkHttpUtils;
 import com.lzy.okhttputils.model.HttpHeaders;
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 b50817e..08dd3ae 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
@@ -15,15 +15,13 @@
 import android.widget.RadioGroup;
 
 import com.bsk.zhangbo.demoforbsk.R;
-import cn.com.basic.face.adapter.SupervisoryAdapter;
+import cn.com.basic.face.adapter.SupervisoryBottomAdapter;
 import cn.com.basic.face.base.BaseFragment;
 import cn.com.basic.face.service.CheckInMng;
-import cn.com.basic.face.util.RtspFaceNative;
+import com.bsk.zhangbo.demoforbsk.util.RtspFaceNative;
 import cn.com.basic.face.util.WindowsUtil;
-import cn.com.basic.face.widget.MyGLSurfaceView;
 import com.camnter.easyrecyclerview.widget.EasyRecyclerView;
 import com.lidroid.xutils.view.annotation.ViewInject;
-import com.orhanobut.logger.Logger;
 
 import java.util.ArrayList;
 import java.util.List;
@@ -34,10 +32,6 @@
  */
 
 public class SupervisoryFragment extends BaseFragment {
-
-    static {
-        //System.loadLibrary("rtspface");//xiuxi
-    }
 
     @ViewInject(R.id.fragment_supervisory_bottom_left_radio_group)
     private RadioGroup fragment_supervisory_bottom_left_radio_group;
@@ -51,32 +45,18 @@
     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_visitor_list)
-    private EasyRecyclerView fragment_supervisory_bottom_visitor_list;
+    @ViewInject(R.id.fragment_supervisory_enter_camera)
+    SurfaceView fragment_supervisory_enter_camera;
+    @ViewInject(R.id.fragment_supervisory_exit_camera)
+    SurfaceView fragment_supervisory_exit_camera;
 
-    private SupervisoryAdapter mAdapter;
+    private SupervisoryBottomAdapter mAdapter;
     private List mList;
 
-    //鎾斁
-
-    String mSourceString = "clips/testfile.mp4";
-
-    SurfaceView fragment_supervisory_enter_camera;
-    SurfaceView fragment_supervisory_exit_camera;
-    SurfaceHolder mSurfaceHolder1;
-
-    VideoSink mSelectedVideoSink;
-
-
-    SurfaceHolderVideoSink mSurfaceHolder1VideoSink;
-
-    VideoSink mNativeCodecPlayerVideoSink;
-    GLViewVideoSink mGLView1VideoSink;
-    boolean mCreated = false;
-    boolean mIsPlaying = false;
-
-
-
+    static {
+        System.loadLibrary("rtspface");
+        RtspFaceNative.init();
+    }
 
     private static SupervisoryFragment instance = new SupervisoryFragment();
 
@@ -91,101 +71,25 @@
 
     @Override
     protected void initViews(View view, Bundle savedInstanceState) {
-        fragment_supervisory_bottom_left_radio_group = (RadioGroup) view.findViewById(R.id.fragment_supervisory_bottom_left_radio_group);
-        fragment_supervisory_bottom_visitor_radio_button = (RadioButton) view.findViewById(R.id.fragment_supervisory_bottom_visitor_radio_button);
-        fragment_supervisory_bottom_attendance_radio_button = (RadioButton) view.findViewById(R.id.fragment_supervisory_bottom_attendance_radio_button);
-        fragment_supervisory_bottom_visitor_background = view.findViewById(R.id.fragment_supervisory_bottom_visitor_background);
-        fragment_supervisory_bottom_attendance_background = view.findViewById(R.id.fragment_supervisory_bottom_attendance_background);
-        fragment_supervisory_bottom_register_list = (EasyRecyclerView) view.findViewById(R.id.fragment_supervisory_bottom_register_list);
-        fragment_supervisory_bottom_visitor_list = (EasyRecyclerView) view.findViewById(R.id.fragment_supervisory_bottom_visitor_list);
-        fragment_supervisory_bottom_visitor_radio_button.setChecked(true);
         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 SupervisoryAdapter(getActivity());
-
-
-        fragment_supervisory_exit_camera = (SurfaceView) view.findViewById(R.id.fragment_supervisory_exit_camera);
-        fragment_supervisory_enter_camera = (SurfaceView) view.findViewById(R.id.fragment_supervisory_enter_camera);
-        RtspFaceNative.init();
-        RtspFaceNative.setSurface(1, fragment_supervisory_enter_camera.getHolder().getSurface());
-        RtspFaceNative.setSurface(2, fragment_supervisory_exit_camera.getHolder().getSurface());
-
-        mSurfaceHolder1 = fragment_supervisory_enter_camera.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(fragment_supervisory_exit_camera instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView) fragment_supervisory_exit_camera).onResume();
-        }
-        if (mGLView1VideoSink == null) {
-            mGLView1VideoSink = new GLViewVideoSink(fragment_supervisory_exit_camera);
-        }
-        mSelectedVideoSink = mGLView1VideoSink;
-
-
-        //鎾斁寤惰繜锛堝垵濮嬪寲杈冩參锛屽彲鑳藉鑷存棤娉曟甯告挱鏀撅級
-        Thread thread = new Thread(new Runnable() {
+        mAdapter = new SupervisoryBottomAdapter(getActivity());
+        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");
-                        }
-                    }
-                    if (mCreated) {
-                        mIsPlaying = !mIsPlaying;
-                        //setPlayingStreamingMediaPlayer(mIsPlaying);
-                    }
-
-                } catch (InterruptedException e) {
+                    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");
+                } catch (Exception e) {
                     e.printStackTrace();
                 }
             }
-        });
-        thread.start();//xiuxi
+        }).start();
     }
 
     @Override
@@ -193,20 +97,21 @@
         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_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;
+//                }
+                reloadBottomList();
             }
         });
     }
@@ -215,23 +120,24 @@
     public void setMenuVisibility(boolean menuVisible) {
         super.setMenuVisibility(menuVisible);
         if (menuVisible) {
-//            reloadBottomList();
+            reloadBottomList();
         }
     }
 
     private void reloadBottomList() {
-        mList = new ArrayList();
-        CheckInMng.getInstance().findVisitorList();
-        mAdapter = new SupervisoryAdapter(getActivity());
-        mAdapter.setList(mList);
-        fragment_supervisory_bottom_register_list.setAdapter(mAdapter);
+        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);
+        }
     }
 
     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) {
@@ -243,123 +149,4 @@
         }
     }
 
-    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");
-            }
-        }
-    }
-
-    /**
-     * Called when the activity is about to be paused.
-     */
-    @Override
-    public void onPause() {
-        mIsPlaying = false;
-        if(fragment_supervisory_exit_camera instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView) fragment_supervisory_exit_camera).onPause();
-        }
-        //setPlayingStreamingMediaPlayer(false);//xiuxi
-        super.onPause();
-    }
-
-    @Override
-    public void onResume() {
-        super.onResume();
-        if(fragment_supervisory_exit_camera instanceof MyGLSurfaceView) {
-            ((MyGLSurfaceView) fragment_supervisory_exit_camera).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());
-            }
-
-        }
-
-    }
 }
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
deleted file mode 100644
index 0746e56..0000000
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/RtspFaceNative.java
+++ /dev/null
@@ -1,33 +0,0 @@
-package cn.com.basic.face.util;
-
-import android.view.Surface;
-
-/**
- * Created by xiuxi on 2017/3/21.
- */
-
-public class RtspFaceNative {
-
-//    public static native void init();
-//    public static native void setSurface(int cameraIdx, Surface surface);
-//    public static native boolean createPlayer(int cameraIdx, String uri);
-//    public static native void shutdown(int cameraIdx);
-//    // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
-//    public static native boolean setFaceCallback(int cameraIdx, String func);
-//    public static native void lockFace(int cameraIdx);
-//    public static native void releaseFace(int cameraIdx);
-//    public static native boolean getFaceList(int cameraIdx, byte[] faceListPb);
-//    public static native boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages);
-
-    public static void init() {};
-    public static  void setSurface(int cameraIdx, Surface surface){};
-    public static  boolean createPlayer(int cameraIdx, String uri){return true;};
-    public static  void shutdown(int cameraIdx){};
-    // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
-    public static  boolean setFaceCallback(int cameraIdx, String func){return true;};
-    public static  void lockFace(int cameraIdx){};
-    public static  void releaseFace(int cameraIdx){};
-    public static  boolean getFaceList(int cameraIdx, byte[] faceListPb){return true;};//浜岃繘鍒�
-    public static  boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages){return true;};//鍥剧墖
-
-}
diff --git a/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java b/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java
new file mode 100644
index 0000000..98a10b3
--- /dev/null
+++ b/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/util/RtspFaceNative.java
@@ -0,0 +1,33 @@
+package com.bsk.zhangbo.demoforbsk.util;
+
+import android.view.Surface;
+
+/**
+ * Created by xiuxi on 2017/3/21.
+ */
+
+public class RtspFaceNative {
+
+    public static native void init();
+    public static native void setSurface(int cameraIdx, Surface surface);
+    public static native boolean createPlayer(int cameraIdx, String uri);
+    public static native void shutdown(int cameraIdx);
+    // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
+    public static native boolean setFaceCallback(int cameraIdx, String func);
+    public static native void lockFace(int cameraIdx);
+    public static native void releaseFace(int cameraIdx);
+    public static native boolean getFaceList(int cameraIdx, byte[] faceListPb);
+    public static native boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages);
+
+//    public static void init() {};
+//    public static  void setSurface(int cameraIdx, Surface surface){};
+//    public static  boolean createPlayer(int cameraIdx, String uri){return true;};
+//    public static  void shutdown(int cameraIdx){};
+//    // typedef void (* Java_com_example_nativecodec_NativeCodec_FaceCallback_func)(int cameraIdx, int count);
+//    public static  boolean setFaceCallback(int cameraIdx, String func){return true;};
+//    public static  void lockFace(int cameraIdx){};
+//    public static  void releaseFace(int cameraIdx){};
+//    public static  boolean getFaceList(int cameraIdx, byte[] faceListPb){return true;};//浜岃繘鍒�
+//    public static  boolean getFaceImages(int cameraIdx, byte[] faceImagesIdx, byte[] faceImages){return true;};//鍥剧墖
+
+}
diff --git a/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_supervisory.xml b/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_supervisory.xml
index 0eae5cd..7301580 100644
--- a/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_supervisory.xml
+++ b/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_supervisory.xml
@@ -156,7 +156,7 @@
                     android:layout_width="match_parent"
                     android:layout_height="@dimen/view_size_0"
                     android:layout_weight="1"
-                    android:background="@color/colorPrimary"></View>
+                    android:background="@color/colorPrimary"/>
 
                 <View
                     android:id="@+id/fragment_supervisory_bottom_attendance_background"
@@ -164,7 +164,7 @@
                     android:layout_height="@dimen/view_size_0"
                     android:layout_weight="1"
                     android:background="@color/colorPrimary"
-                    android:visibility="invisible"></View>
+                    android:visibility="invisible"/>
             </LinearLayout>
         </RelativeLayout>
         <RelativeLayout

--
Gitblit v1.8.0