- QSVideoView接口完善,功能丰富
- 支持设置视频比例
- 支持两种悬浮窗
- 支持扩展解码器
- 自动切换全屏
- 支持静音等
- 只需100行java代码即可打造自己的播放器!提供QSVideoViewHelp辅助类,该类提供了常用控件的逻辑和手势调节支持,可快速自定义ui打造自己的播放器,不用写一行播放逻辑
- 架构设计优良,模块化可扩展设计,解码模块目前提供了 AndroidMedia(系统自带)、ijkMedia(基于ffmepg)+ijkExoMedia(基于exo)、ExoMedia(2.0.4)解码器
- 根据系统版本自动选择SurfaceView和TextureView
- 支持本地视频,在线视频,m3u8直播等
- 提供DemoQSVideoView成品播放器,支持手势
- 提供list视频列表自动销毁播放框架,可实现qq微博的视频列表效果
Preview
使用说明
下载项目 添加qsvideoplayer文件夹为自己的项目依赖即可
源码有4个解码器,根据需求自行选择需要的解码器:
1.一般简单播放视频AndroidMedia足够(体积最小,无依赖) 2.有点需求可选择AndroidMedia+ExoMedia(1MB) 3.需求高的可选AndroidMedia+(ijkMedia+ijkExoMedia)(2MB单v7a包) 目前测试解码效果ijkMedia兼容性最好,AndroidMedia个别视频有半途中断BUG,exo无明显缺陷 ps:删除ijk解码器: build.gradle注释掉所有依赖,media包里删除IjkBaseMedia IjkExoMedia IjkMedia三个类即可 删除exo解码器: libs里删除jar,media包里删除ExoMedia即可混淆
-dontwarn org.song.videoplayer.**-keep class org.song.videoplayer.** { *; }复制代码
QSVideoView API接口
void setUp(String url, Object... objects);//设置视频地址 void play();//播放 void pause();//暂停 void seekTo(int duration);//进度调节 void setPlayListener(PlayListener playListener);//播放监听 参数含义参照IVideoPlayer void setAspectRatio(int aspectRatio);//设置视频比例 参数见IRenderView void setDecodeMedia(Class claxx);//设置解码模块 boolean onBackPressed();//返回键退出全屏 boolean isPlaying();//是否播放中 void enterWindowFullscreen();//全屏 void quitWindowFullscreen();//退出全屏 boolean enterWindowFloat(FloatParams floatParams);//浮窗 false没权限 void quitWindowFloat();//退出浮窗 boolean setMute(boolean isMute);//是否静音 false不支持 void release();//销毁 int getPosition();//获取播放进度 int getDuration();//获取视频时长 int getVideoWidth();//获取视频宽 int getVideoHeight();//获取视频长 int getCurrentMode();//获得播放器当前的模式(全屏,普通,浮窗) int getCurrentState();//获得播放器当前的状态(播放,暂停,完成...)复制代码
Demo使用
JAVA
//DemoQSVideoView的ui用的jc播放器 DemoQSVideoView qsVideoView = (DemoQSVideoView) findViewById(R.id.xxx); qsVideoView.setUp(url, "这是一一一一一一一一一个标题"); qsVideoView.getCoverImageView().setImageResource(R.mipmap.cover);//封面 //设置监听 qsVideoView.setPlayListener(new PlayListener() { @Override public void onStatus(int status) {//播放器的ui状态 if (status == IVideoPlayer.STATE_AUTO_COMPLETE) qsVideoView.quitWindowFullscreen();//播放完成退出全屏 } @Override//全屏/普通... public void onMode(int mode) { } @Override//播放事件 初始化完成/缓冲/出错/... public void onEvent(int what, Integer... extra) { } }); //进入全屏的模式 0横屏 1竖屏 2传感器自动横竖屏 3根据视频比例自动确定横竖屏 -1什么都不做 qsVideoView.enterFullMode=1; qsVideoView.play();复制代码
返回键退出全屏
@Override public void onBackPressed() { if (qsVideoView.onBackPressed()) return; super.onBackPressed(); }复制代码
悬浮窗
FloatParams floatParams = new FloatParams(); floatParams.x = 0;//浮窗中心坐标x floatParams.y = 0;//浮窗中心坐标y floatParams.w = 540;//宽 floatParams.h = 270;//高 floatParams.round = 30;//浮窗圆角 需SDK_INT >= 21 floatParams.fade = 0.8f;//透明度 需SDK_INT >= 11 floatParams.canMove = true;//是否可以拖动 floatParams.systemFloat = true;TRUE系统浮窗需要权限 FALSE界面内浮窗 if (!qsVideoView.enterWindowFloat(floatParams)) { Toast.makeText(this,"没有浮窗权限",Toast.LENGTH_LONG).show(); Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())); startActivityForResult(intent, 0); } }复制代码
XML
复制代码
AndroidManifest
复制代码
DIY播放器:
0.read source code.
1.可直接修改DemoQSVideoView改造自己的播放器 2.继承QSVideoViewHelp参考DemoQSVideoView,源码均有注释,不用写一行播放逻辑 (1) 子类提供layout布局,布局里需要help类实现逻辑的控件,设置id为以下特定id即可(2) java代码里设置各个状态的ui即可完成自己的播放器,具体参考DemoQSVideoView 3.直接使用QSVideoView,自己写控制ui和逻辑 (继承关系:DemoQSVideoView → QSVideoViewHelp → QSVideoView)- //如播放按钮定义,注意: @id 没有加号,这样定义父类会自动完成该按钮逻辑
复制代码
Log
v2.2.1(2018-1-30)
- add floatwindow in activity(增加界面内悬浮窗功能,无需权限)
- add event(seekbar) listener(增加seekbar事件监听)
v2.2.0(2018-1-28)
- add floatwindow(增加悬浮窗功能)
v2.1.1(2018-1-8)
- -add mute(支持静音)
- -add enterfullmode(增加进入全屏的模式,根据视频自动确定横竖屏)
- -support content uri(支持uri播放)
- -fullwindow hide navigation(全屏隐藏虚拟按键)
- -fix bug(修复bug)
Github:https://github.com/tohodog/QSVideoPlayer