From 80f61dfdab1e7f7fabdfa0fb4931b5d585e4c7d9 Mon Sep 17 00:00:00 2001 From: zhangbo <zhangbo@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 02 三月 2017 09:49:32 +0800 Subject: [PATCH] 界面,以及部分jni --- VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/ui/fragment/OneFragment.java | 169 +++++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 160 insertions(+), 9 deletions(-) diff --git a/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/ui/fragment/OneFragment.java b/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/ui/fragment/OneFragment.java index 8cc21b3..8af1b20 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/ui/fragment/OneFragment.java +++ b/VisitFace/DemoForBsk/app/src/main/java/com/bsk/zhangbo/demoforbsk/ui/fragment/OneFragment.java @@ -1,11 +1,16 @@ package com.bsk.zhangbo.demoforbsk.ui.fragment; +import android.content.res.AssetManager; import android.graphics.Rect; import android.os.Bundle; import android.support.v4.view.ViewPager; import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; +import android.util.Log; +import android.view.Surface; +import android.view.SurfaceHolder; +import android.view.SurfaceView; import android.view.View; import android.widget.RadioButton; import android.widget.RadioGroup; @@ -26,17 +31,53 @@ * Created by zhangbo on 2017/2/15. */ -public class OneFragment extends BaseFragment{ +public class OneFragment extends BaseFragment { private RadioGroup mRadioGroup; - private RadioButton mRadioButton1,mRadioButton2; - private View mRadioLine1,mRadioLine2; + private RadioButton mRadioButton1, mRadioButton2; + private View mRadioLine1, mRadioLine2; private OneBottomRecylerViewAdapter mAdapter; private List mList; - private EasyRecyclerView mRecyclerViewRegister,mRecyclerViewUser; + private EasyRecyclerView mRecyclerViewRegister, mRecyclerViewUser; + + + //鎾斁 + + +// SurfaceHolderVideoSink mSurfaceHolder1VideoSink; +// VideoSink mSelectedVideoSink; +// VideoSink mNativeCodecPlayerVideoSink; +// SurfaceView mSurfaceView1; +// SurfaceHolder mSurfaceHolder1; +// boolean mCreated = false; +// boolean mIsPlaying = false; +// String mSourceString = "clips/testfile.mp4"; + + /** + * Native methods, implemented in jni folder + */ +// public static native void createEngine(); +// +// public static native boolean createStreamingMediaPlayer(AssetManager assetMgr, String filename); +// +// public static native void setPlayingStreamingMediaPlayer(boolean isPlaying); +// +// public static native void shutdown(); +// +// public static native void setSurface(Surface surface); +// +// public static native void rewindStreamingMediaPlayer(); + + /** Load jni .so on initialization */ + static { + System.loadLibrary("native-codec-jni"); + } + + public static OneFragment newInstance() { return new OneFragment(); } + @Override protected int getLayoutId() { return R.layout.fragment_one; @@ -53,10 +94,36 @@ mRecyclerViewUser = (EasyRecyclerView) view.findViewById(R.id.recyclerview_user); mRadioButton1.setChecked(true); mRecyclerViewRegister.addItemDecoration(new SpaceItemDecoration()); - GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(),2); + GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), 2); gridLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL); mRecyclerViewRegister.setLayoutManager(gridLayoutManager); mAdapter = new OneBottomRecylerViewAdapter(getActivity()); + + + // set up the Surface 1 video sink +// mSurfaceView1 = (SurfaceView) view.findViewById(R.id.surfaceview1); +// mSurfaceHolder1 = mSurfaceView1.getHolder(); +// +// mSurfaceHolder1.addCallback(new SurfaceHolder.Callback() { +// +// @Override +// public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { +// Log.v("", "surfaceChanged format=" + format + ", width=" + width + ", height=" +// + height); +// } +// +// @Override +// public void surfaceCreated(SurfaceHolder holder) { +// Log.v("", "surfaceCreated"); +// setSurface(holder.getSurface()); +// } +// +// @Override +// public void surfaceDestroyed(SurfaceHolder holder) { +// Log.v("", "surfaceDestroyed"); +// } +// +// }); } @Override @@ -69,7 +136,7 @@ mRadioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { - switch (checkedId){ + switch (checkedId) { case R.id.radio1: mRadioLine1.setVisibility(View.VISIBLE); mRadioLine2.setVisibility(View.INVISIBLE); @@ -89,13 +156,27 @@ @Override protected void initData() { +// switchSurface(); mList = new ArrayList(); - for (int i=0;i<25;i++){ + for (int i = 0; i < 25; i++) { mList.add(""); } mAdapter.setList(mList); mRecyclerViewRegister.setAdapter(mAdapter); + + +// mSurfaceHolder1VideoSink = new SurfaceHolderVideoSink(mSurfaceHolder1); +// mSelectedVideoSink = mSurfaceHolder1VideoSink; +// mSelectedVideoSink.useAsSinkForNative(); +// mNativeCodecPlayerVideoSink = mSelectedVideoSink; +// +// mCreated = createStreamingMediaPlayer(getResources().getAssets(), +// mSourceString); +// mIsPlaying = !mIsPlaying; +// setPlayingStreamingMediaPlayer(mIsPlaying); + } + private class SpaceItemDecoration extends RecyclerView.ItemDecoration { @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { @@ -103,8 +184,8 @@ // outRect.bottom = WindowsUtil.dip2px(getActivity(), 7); outRect.right = WindowsUtil.dip2px(getActivity(), 15); - if (parent.getChildLayoutPosition(view) == 0 || parent.getChildLayoutPosition(view) == 1){ - outRect.left = WindowsUtil.dip2px(getActivity(),14); + if (parent.getChildLayoutPosition(view) == 0 || parent.getChildLayoutPosition(view) == 1) { + outRect.left = WindowsUtil.dip2px(getActivity(), 14); } if (parent.getChildLayoutPosition(view) % 2 == 0) { outRect.bottom = WindowsUtil.dip2px(getActivity(), 7); @@ -116,4 +197,74 @@ // } } } + + +// void switchSurface() { +// if (mCreated && mNativeCodecPlayerVideoSink != mSelectedVideoSink) { +// // shutdown and recreate on other surface +// Log.i("@@@", "shutting down player"); +// shutdown(); +// mCreated = false; +// mSelectedVideoSink.useAsSinkForNative(); +// mNativeCodecPlayerVideoSink = mSelectedVideoSink; +// if (mSourceString != null) { +// Log.i("@@@", "recreating player"); +// mCreated = createStreamingMediaPlayer(getResources().getAssets(), mSourceString); +// mIsPlaying = false; +// } +// } +// } + +// /** +// * Called when the activity is about to be paused. +// */ +// @Override +// public void onPause() { +// mIsPlaying = false; +// setPlayingStreamingMediaPlayer(false); +// super.onPause(); +// } +// +// /** +// * Called when the activity is about to be destroyed. +// */ +// @Override +// public void onDestroy() { +// shutdown(); +// 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); +// setSurface(s); +// } +// +// } } -- Gitblit v1.8.0