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