Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tohodog/qsvideoplayer

安卓视频播放器AndroidVideoplayer,架构设计优良功能丰富,支持多种解码,支持设置比例,浮窗,倍速,静音等
https://github.com/tohodog/qsvideoplayer

android exo ffmpeg ijkplayer videoplayer

Last synced: 3 days ago
JSON representation

安卓视频播放器AndroidVideoplayer,架构设计优良功能丰富,支持多种解码,支持设置比例,浮窗,倍速,静音等

Awesome Lists containing this project

README

        

![logo][logopng]




---

[![GitHub release][relesesvg]][relesezip] [![api][apisvg]][api] [![License][licensesvg]][license]

* QSVideoView接口完善,功能丰富
* 支持设置视频比例
* 支持两种悬浮窗
* 支持扩展解码器
* 智能切换全屏
* 支持本地缓存
* 支持倍速静音等
* 架构设计优良,模块化可扩展设计,解码模块目前提供了 AndroidMedia(系统自带)、ijkMedia(基于ffmepg)+ijkExoMedia(基于exo)、ExoMedia(2.0.4)解码器
* 可选择SurfaceView和TextureView
* 支持本地视频,在线视频,m3u8直播等
* 提供DemoQSVideoView成品播放器,支持手势,清晰度
* 极速DIY:只需100行java代码即可打造自己的播放器!
提供QSVideoViewHelp辅助类,该类提供了常用控件的逻辑和手势调节支持,可快速自定义ui打造自己的播放器,不用写一行播放逻辑
* 提供list视频列表自动销毁播放框架
* 提供一行代码集成弹幕框架

![qrcode][qrpng]


[![apkurl][apkurlsvg]][apkurl]

## Preview
![](https://github.com/tohodog/QSVideoPlayer/raw/master/source/main.png)
![](https://github.com/tohodog/QSVideoPlayer/raw/master/source/full1.png)
![](https://github.com/tohodog/QSVideoPlayer/raw/master/source/lsit.gif)
![](https://github.com/tohodog/QSVideoPlayer/raw/master/source/float.png)
![](https://github.com/tohodog/QSVideoPlayer/raw/master/source/full2.jpg)

## 使用说明

#### Gradle 自动集成
```
allprojects {
repositories {
maven {
url "https://jitpack.io"
}
}
}

dependencies {
implementation 'com.github.tohodog:QSVideoPlayer:2.2.9'

//是否需要其他架构的ijk解码器支持,默认只有v7
//so不存在报错可以配置ndk{abiFilters 'armeabi-v7a'}或导入下面的包
//implementation 'tv.danmaku.ijk.media:ijkplayer-armv5:0.8.8'
//implementation 'tv.danmaku.ijk.media:ijkplayer-arm64:0.8.8'
//implementation 'tv.danmaku.ijk.media:ijkplayer-x86:0.8.8'
//implementation 'tv.danmaku.ijk.media:ijkplayer-x86_64:0.8.8'
}
```

#### 手动集成

下载项目 添加qsvideoplayer文件夹为自己的项目依赖即可
可根据需求自行选择需要的解码器:

默认一般简单播放视频AndroidMedia足够(体积最小,无依赖)

需求高的可选AndroidMedia+(ijkMedia+ijkExoMedia)(2MB单v7a包)

目前测试解码效果ijkMedia兼容性最好,AndroidMedia个别视频有半途中断BUG,exo无明显缺陷

ps:
如需精简删除ijk解码器: build.gradle注释掉所有依赖,media包里删除IjkBaseMedia IjkExoMedia IjkMedia三个类即可

弹幕、exo解码器在demo里,需要自行下载demo复制集成

## QSVideoView API接口
```
void setUp(String url, Object... objects);//设置视频地址

void play();//播放/初始化(完成自动播放)

void prePlay();//初始化(完成不会播放)

void pause();//暂停

void seekTo(int duration);//进度调节

void setPlayListener(PlayListener playListener);//播放监听 参数含义参照IVideoPlayer

void addPlayListener(PlayListener playListener);//多播放监听

void removePlayListener(PlayListener playListener);//移除播放监听

void setAspectRatio(int aspectRatio);//设置视频比例 参数见IRenderView

void setDecodeMedia(Class extends BaseMedia> claxx);//设置解码模块

void openCache();//打开缓存

boolean onBackPressed();//返回键退出全屏

boolean isPlaying();//是否播放中

void enterWindowFullscreen();//全屏

void quitWindowFullscreen();//退出全屏

boolean enterWindowFloat(FloatParams floatParams);//浮窗 false没权限

void quitWindowFloat();//退出浮窗

boolean setMute(boolean isMute);//是否静音 false不支持

boolean setSpeed(float rate);//设置播放倍速,false不支持

void release();//销毁

Bitmap getCurrentFrame();//截图

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, "这是一一一一一一一一一个标题");

//设置多个清晰度和ijk配置
//List list = new ArrayList<>();
//list.add(new IjkMedia.Option(IjkMediaPlayer.OPT_CATEGORY_PLAYER, "soundtouch", 1));
//demoVideoView.setUp(
// QSVideo.Build(url).title("这是标清标题").definition("标清").resolution("标清 720P").build(),
// QSVideo.Build(url).title("这是高清标题").definition("高清").resolution("高清 1080P").option(list).build());

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=3;
qsVideoView.play();
```

### 返回键退出全屏
```
@Override
public void onBackPressed() {
if (qsVideoView.onBackPressed())
return;
super.onBackPressed();
}
```

### XML
```

```

### AndroidManifest
```


```

### 悬浮窗
```
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.canCross = false;//是否可以越屏幕边界
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);
}
}
```

### 生命周期控制
实现后台暂停播放,超过15秒销毁,回来还原播放状态,体验好
```
private boolean playFlag;//记录退出时播放状态 回来的时候继续播放
private int position;//记录销毁时的进度 回来继续该进度播放
private Handler handler = new Handler();

@Override
public void onResume() {
super.onResume();
if (playFlag)
demoVideoView.play();
handler.removeCallbacks(runnable);
if (position > 0) {
demoVideoView.seekTo(position);
position = 0;
}
}

@Override
public void onPause() {
super.onPause();
if (demoVideoView.isSystemFloatMode())
return;
//暂停
playFlag = demoVideoView.isPlaying();
demoVideoView.pause();
}

@Override
public void onStop() {
super.onStop();
if (demoVideoView.isSystemFloatMode())
return;
//进入后台不马上销毁,延时15秒
handler.postDelayed(runnable, 1000 * 15);
}

@Override
public void onDestroy() {
super.onDestroy();//销毁
if (demoVideoView.isSystemFloatMode())
demoVideoView.quitWindowFloat();
demoVideoView.release();
handler.removeCallbacks(runnable);
}

private Runnable runnable = new Runnable() {
@Override
public void run() {
if (demoVideoView.getCurrentState() != IVideoPlayer.STATE_AUTO_COMPLETE)
position = demoVideoView.getPosition();
demoVideoView.release();
}
};
```

## DIY播放器:
0.read source code.


1.可直接修改DemoQSVideoView改造自己的播放器


2.继承QSVideoViewHelp参考DemoQSVideoView,源码均有注释,不用写一行播放逻辑

(1) 子类提供layout布局,布局里需要help类实现逻辑的控件,设置id为以下特定id即可
```











//如播放按钮定义,注意: @id 没有加号,这样定义父类会自动完成该按钮逻辑

```


(2) java代码里设置各个状态的ui即可完成自己的播放器,具体参考DemoQSVideoView


3.直接使用QSVideoView,自己写控制ui和逻辑

(继承关系:DemoQSVideoView → QSVideoViewHelp → QSVideoView)

## Log
### v2.2.9(2021-09-12)
* 全屏虚拟键问题
* 优化
### v2.2.8(2019-04-12)
* 清晰度选择
* 优化
### v2.2.7(2019-01-05)
* 倍速播放
* 优化
### v2.2.5(2018-10-24)
* 支持视频缓存
### v2.2.4(2018-9-1)
* 浮窗超出屏幕回弹效果
* 优化
### v2.2.3(2018-5-12)
* +Danmaku(一行代码集成弹幕)
* +getCurrentFrame(增加截图>=4.0)
* +support systemfloat goback(系统浮窗可返回)
* +perfect listenner(完善事件监听)
### v2.2.2(2018-2-13)
* can get the floatparams after moving(可以获取移动后的浮窗参数)
* 8.0 callback onInfo (804, -1004) problem(8.0断流回调onInfo(804,-1004)问题)
* Immersion Demo(沉浸式Demo)
### 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)

## Other
* 有问题请Add [issues](https://github.com/tohodog/QsVideoPlayer/issues)
* 如果项目对你有帮助的话欢迎[![star][starsvg]][star]
* logo@[mirzazulfan](https://github.com/mirzazulfan)

[logopng]: https://raw.githubusercontent.com/tohodog/QSVideoPlayer/master/source/logo.png

[qrpng]: https://raw.githubusercontent.com/tohodog/QSVideoPlayer/master/source/video_qrcode.png

[relesesvg]: https://img.shields.io/github/release/tohodog/QSVideoPlayer.svg
[relesezip]: https://codeload.github.com/tohodog/QSVideoPlayer/zip/2.2.7

[apkurlsvg]: https://img.shields.io/badge/download-demo.apk-brightgreen.svg?style=flat
[apkurl]: https://raw.githubusercontent.com/tohodog/QSVideoPlayer/master/source/qsvideoplayer.apk

[apisvg]: https://img.shields.io/badge/API-9+-brightgreen.svg
[api]: https://android-arsenal.com/api?level=9

[licensesvg]: https://img.shields.io/badge/License-Apache--2.0-red.svg
[license]: https://github.com/tohodog/QSVideoPlayer/blob/master/LICENSE

[starsvg]: https://img.shields.io/github/stars/tohodog/QSVideoPlayer.svg?style=social&label=Stars
[star]: https://github.com/tohodog/QSVideoPlayer