README.md 13.8 KB
Newer Older
S
readme  
shuyu 已提交
1

G
readme  
guoshuyu 已提交
2
![](./img/home_logo.png)
S
readme  
shuyu 已提交
3

S
Shuyu Guo 已提交
4
## 基于[IJKPlayer](https://github.com/Bilibili/ijkplayer)(兼容系统MediaPlayer与EXOPlayer2),实现了多功能的视频播放器。 (请仔细阅读下方各项说明,大多数问题可在下方找到解答)。
S
Shuyu Guo 已提交
5

S
Shuyu Guo 已提交
6
> ## [如果克隆太慢或者图片看不到,可尝试从码云地址下载](https://gitee.com/CarGuo/GSYVideoPlayer)
S
Shuyu Guo 已提交
7

S
Shuyu Guo 已提交
8
类型 | 功能
S
Shuyu Guo 已提交
9
-------- | ---
G
readme  
guoshuyu 已提交
10
**缓存**|**边播边缓存,使用了[AndroidVideoCache](https://github.com/danikula/AndroidVideoCache);ExoPlayer使用SimpleCache。**
S
Shuyu Guo 已提交
11
**协议**|**h263\4\5、Https、concat、rtsp、hls、rtmp、crypto、mpeg等等。[(ijk模式格式支持)](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/DECODERS.md)**
G
readme  
guoshuyu 已提交
12 13 14 15 16 17
**滤镜**|**简单滤镜(马赛克、黑白、色彩过滤、高斯、模糊、模糊等等20多种)、动画、(水印、画面多重播放等)。**
**帧图**|**视频第一帧、视频帧截图功能,视频生成gif功能。**
**播放**|**列表播放、列表连续播放、重力旋转与手动旋转、视频本身rotation旋转属性、快播和慢播、网络视频加载速度。**
**画面**|**调整显示比例:默认、16:9、4:3、填充;播放时旋转画面角度(0,90,180,270);镜像旋转。**
**内核**|**IJKPlayer、EXOPlayer、MediaPlayer切换、自定义内核**
**布局**|**全屏与非全屏两套布局切换、没有任何操作控件的纯播放支持、弹幕功能、继承自定义任何布局。**
S
Shuyu Guo 已提交
18
**播放**|**单例播放、多个同时播放、视频列表滑动自动播放、列表切换详情页面无缝播放。**
G
readme  
guoshuyu 已提交
19 20
**窗口**|**小窗口、多窗体下(包括桌面)的小窗口播放。**
**广告**|**片头广告、跳过广告支持、中间插入广告功能。**
G
guoshuyu 已提交
21
**字幕**|**[exo2模式下支持自定增加外挂字幕](https://github.com/CarGuo/GSYVideoPlayer/tree/master/app/src/main/java/com/example/gsyvideoplayer/exosubtitle)。**
G
readme  
guoshuyu 已提交
22 23
**更多**|**暂停前后台切换不黑屏;调整不同清晰度的支持;无缝切换支持;锁定/解锁全屏点击功能;进度条小窗口预览(测试)。**
**自定义**|**可自定义渲染层、自定义管理层、自定义播放层(控制层)、自定义缓存层。**
G
readme  
guoshuyu 已提交
24

S
Shuyu Guo 已提交
25
[ ![Download](https://api.bintray.com/packages/carguo/GSYVideoPlayer/gsyVideoPlayer-java/images/download.svg) ](https://bintray.com/carguo/GSYVideoPlayer/gsyVideoPlayer-java/_latestVersion)
S
shuyu 已提交
26
[![](https://jitpack.io/v/CarGuo/GSYVideoPlayer.svg)](https://jitpack.io/#CarGuo/GSYVideoPlayer)
S
shuyu 已提交
27
[ ![Download](https://api.bintray.com/packages/carguo/GSYVideoPlayer/gsyVideoPlayer/images/download.svg) ](https://bintray.com/carguo/GSYVideoPlayer/gsyVideoPlayer/_latestVersion)
S
readme  
shuyu 已提交
28
[![Build Status](https://travis-ci.org/CarGuo/GSYVideoPlayer.svg?branch=master)](https://travis-ci.org/CarGuo/GSYVideoPlayer)
S
shuyu 已提交
29

S
Shuyu Guo 已提交
30 31 32 33 34 35
[]()
[![GitHub stars](https://img.shields.io/github/stars/CarGuo/GSYVideoPlayer.svg)](https://github.com/CarGuo/GSYVideoPlayer/stargazers)
[![GitHub forks](https://img.shields.io/github/forks/CarGuo/GSYVideoPlayer.svg)](https://github.com/CarGuo/GSYVideoPlayer/network)
[![GitHub issues](https://img.shields.io/github/issues/CarGuo/GSYVideoPlayer.svg)](https://github.com/CarGuo/GSYVideoPlayer/issues)
[![GitHub license](https://img.shields.io/github/license/CarGuo/GSYVideoPlayer.svg)](https://github.com/CarGuo/GSYVideoPlayer/blob/master/LICENSE)

G
guoshuyu 已提交
36 37 38 39 40 41

| 公众号   | 掘金     |  知乎    |  CSDN   |   简书   
|---------|---------|--------- |---------|---------|
| GSYTech  |  [点我](https://juejin.im/user/582aca2ba22b9d006b59ae68/posts)    |   [点我](https://www.zhihu.com/people/carguo)       |   [点我](https://blog.csdn.net/ZuoYueLiang)  |   [点我](https://www.jianshu.com/u/6e613846e1ea)  


S
Shuyu Guo 已提交
42
![](http://img.cdn.guoshuyu.cn/WeChat-Code)
S
Shuyu Guo 已提交
43

G
guoshuyu 已提交
44 45
### [--------------Demo APK 下载地址---------------](https://github.com/CarGuo/GSYVideoPlayer/releases)

S
Shuyu Guo 已提交
46
## 一、使用依赖
S
readme  
shuyu 已提交
47

S
Shuyu Guo 已提交
48
#### 7.0版本使用了anndroidx,support版本请看6.x.x,请查看:[--- 版本更新说明 - 入口](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/UPDATE_VERSION.md)。
49

50
### 1、JCenter 引入方法(推荐)
S
shuyu 已提交
51

S
Shuyu Guo 已提交
52
**你可以选择下面三种的其中一种,在module下的build.gradle添加。**
53

S
shuyu 已提交
54
#### A、直接引入
S
shuyu 已提交
55
```
S
shuyu 已提交
56
//完整版引入
G
guoshuyu 已提交
57
implementation 'com.shuyu:GSYVideoPlayer:8.0.0'
S
readme  
shuyu 已提交
58

S
shuyu 已提交
59 60
```

S
shuyu 已提交
61
#### B、添加java和你想要的so支持:
62 63

```
G
guoshuyu 已提交
64
implementation 'com.shuyu:gsyVideoPlayer-java:8.0.0'
65

G
guoshuyu 已提交
66
//是否需要ExoPlayer模式
G
guoshuyu 已提交
67
implementation 'com.shuyu:GSYVideoPlayer-exo2:8.0.0'
G
guoshuyu 已提交
68 69

//根据你的需求ijk模式的so
G
guoshuyu 已提交
70 71 72 73 74
implementation 'com.shuyu:gsyVideoPlayer-armv5:8.0.0'
implementation 'com.shuyu:gsyVideoPlayer-armv7a:8.0.0'
implementation 'com.shuyu:gsyVideoPlayer-arm64:8.0.0'
implementation 'com.shuyu:gsyVideoPlayer-x64:8.0.0'
implementation 'com.shuyu:gsyVideoPlayer-x86:8.0.0'
75 76 77

```

S
shuyu 已提交
78
#### C、支持其他格式协议的(mpeg,rtsp, concat、crypto协议)
79

S
Shuyu Guo 已提交
80 81
A、B普通版本支持263/264/265等,对于mpeg编码会有声音无画面情况。
C 引入的so支持mpeg编码和其他补充协议,但是so包相对变大。
82 83
 
```
G
guoshuyu 已提交
84
implementation 'com.shuyu:gsyVideoPlayer-java:8.0.0'
G
guoshuyu 已提交
85 86

//是否需要ExoPlayer模式
G
guoshuyu 已提交
87
implementation 'com.shuyu:GSYVideoPlayer-exo2:8.0.0'
88

G
guoshuyu 已提交
89
//更多ijk的编码支持
G
guoshuyu 已提交
90
implementation 'com.shuyu:gsyVideoPlayer-ex_so:8.0.0'
91 92 93

```

G
readme  
guoshuyu 已提交
94
#### 代码中的全局切换支持(更多请参看下方文档和demo)
95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124

```

//EXOPlayer内核,支持格式更多
PlayerFactory.setPlayManager(Exo2PlayerManager.class);
//系统内核模式
PlayerFactory.setPlayManager(SystemPlayerManager.class);
//ijk内核,默认模式
PlayerFactory.setPlayManager(IjkPlayerManager.class);


//exo缓存模式,支持m3u8,只支持exo
CacheFactory.setCacheManager(ExoPlayerCacheManager.class);
//代理缓存模式,支持所有模式,不支持m3u8等,默认
CacheFactory.setCacheManager(ProxyCacheManager.class);



//切换渲染模式
GSYVideoType.setShowType(GSYVideoType.SCREEN_MATCH_FULL);
//默认显示比例
GSYVideoType.SCREEN_TYPE_DEFAULT = 0;
//16:9
GSYVideoType.SCREEN_TYPE_16_9 = 1;
//4:3
GSYVideoType.SCREEN_TYPE_4_3 = 2;
//全屏裁减显示,为了显示正常 CoverImageView 建议使用FrameLayout作为父布局
GSYVideoType.SCREEN_TYPE_FULL = 4;
//全屏拉伸显示,使用这个属性时,surface_container建议使用FrameLayout
GSYVideoType.SCREEN_MATCH_FULL = -4;
G
readme  
guoshuyu 已提交
125 126 127 128 129
/***
 * SCREEN_TYPE_CUSTOM 下自定义显示比例
 * @param screenScaleRatio  高宽比,如 16:9
 */
public static void setScreenScaleRatio(float screenScaleRatio)
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152


//切换绘制模式
GSYVideoType.setRenderType(GSYVideoType.SUFRACE);
GSYVideoType.setRenderType(GSYVideoType.GLSURFACE);
GSYVideoType.setRenderType(GSYVideoType.TEXTURE);


//ijk关闭log
IjkPlayerManager.setLogLevel(IjkMediaPlayer.IJK_LOG_SILENT);


//exoplayer自定义MediaSource
ExoSourceManager.setExoMediaSourceInterceptListener(new ExoMediaSourceInterceptListener() {
    @Override
    public MediaSource getMediaSource(String dataSource, boolean preview, boolean cacheEnable, boolean isLooping, File cacheDir) {
        //可自定义MediaSource
        return null;
    }
});

```

G
readme  
guoshuyu 已提交
153
### [--- 更多依赖方式请点击 - ](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/DEPENDENCIES.md)
S
Shuyu Guo 已提交
154

S
Shuyu Guo 已提交
155
## 二、其他推荐
S
Shuyu Guo 已提交
156

S
Shuyu Guo 已提交
157
### * QQ群,有兴趣的欢迎(平时吹水吐槽多,因为人数饱和,目前开启付费入群):174815284 。
S
Shuyu Guo 已提交
158
### * [Flutter Github客户端](https://github.com/CarGuo/gsy_github_app_flutter) 、[React Native Github客户端](https://github.com/CarGuo/GSYGithubAPP) 、 [Weex Github客户端](https://github.com/CarGuo/GSYGithubAPPWeex) 、 [原生 Kotlin Github客户端](https://github.com/CarGuo/GSYGithubAPPKotlin)
S
Shuyu Guo 已提交
159
### * [RxFFmpeg Android 的音视频编辑工具](https://github.com/microshow/RxFFmpeg)
G
guoshuyu 已提交
160
### * [oarplayer Rtmp播放器,基于MediaCodec与srs-librtmp,不依赖ffmpeg](https://github.com/qingkouwei/oarplayer)
S
Shuyu Guo 已提交
161 162
### * [RickText](https://github.com/CarGuo/RickText)
### * [LazyRecyclerAdapter](https://github.com/CarGuo/LazyRecyclerAdapter)
S
Shuyu Guo 已提交
163

S
Shuyu Guo 已提交
164

S
Shuyu Guo 已提交
165
## 三、文档Wiki
S
readme  
shuyu 已提交
166

G
readme  
guoshuyu 已提交
167 168
文档 | 传送门
-------- | ---
G
guoshuyu 已提交
169
**使用说明**|***[--- 简单使用,快速上手文档](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/USE.md)***
G
readme  
guoshuyu 已提交
170
**建议阅读**|***[--- 移动开发者必知的音视频基础知识](https://mp.weixin.qq.com/s/HjSdmAsHuvixCH_EWdvk3Q)***
S
Shuyu Guo 已提交
171
**项目解析说明**|***[--- 项目解析说明、包含项目架构和解析](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/GSYVIDEO_PLAYER_PROJECT_INFO.md)***
G
readme  
guoshuyu 已提交
172
接口文档入口|**[--- 使用说明、接口文档 - 入口](https://github.com/CarGuo/GSYVideoPlayer/wiki)**
S
Shuyu Guo 已提交
173
**问题集锦入口**|***[--- 问题集锦 - 入口(大部分你遇到的问题都在这里解决) ](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/QUESTION.md)***
G
guoshuyu 已提交
174
编码格式|**[--- IJK so文件配置格式说明](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/DECODERS.md)**
G
guoshuyu 已提交
175
编译自定义SO|**[--- IJKPlayer编译自定义SO - 入口](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/BUILD_SO.md)**
G
readme  
guoshuyu 已提交
176 177
版本更新说明|**[--- 版本更新说明 - 入口](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/UPDATE_VERSION.md)**

S
readme  
shuyu 已提交
178

G
readme  
guoshuyu 已提交
179
![框架图](./img/StructureChart2.jpg)
G
guoshuyu 已提交
180

S
Shuyu Guo 已提交
181
## 四、运行效果
S
readme  
shuyu 已提交
182

S
Shuyu Guo 已提交
183
* ### 1、打开一个播放(旋转、镜像、填充)
G
readme  
guoshuyu 已提交
184
<img src="./img/11.gif" width="240px" height="426px"/>
S
1.1.5  
shuyu 已提交
185

S
Shuyu Guo 已提交
186
* ### 2、列表/详情模式(动画、旋转、小窗体)
S
Shuyu Guo 已提交
187 188

<div>
G
readme  
guoshuyu 已提交
189 190 191
<img src="./img/22.gif" width="240px" height="426px"/>
<img src="./img/33.gif" width="240px" height="426px"/>
<img src="./img/44.gif" width="240px" height="426px"/>
S
Shuyu Guo 已提交
192
</div>
S
shuyu 已提交
193

S
shuyu 已提交
194
* ### 3、弹幕
G
readme  
guoshuyu 已提交
195
<img src="./img/55.gif" width="240px" height="426px"/>
S
shuyu 已提交
196

G
guoshuyu 已提交
197
* ### 4、滤镜和GL动画
G
readme  
guoshuyu 已提交
198
<img src="./img/09.gif"/>
G
guoshuyu 已提交
199

G
readme  
guoshuyu 已提交
200 201
* ### 6、背景铺满模糊播放

G
readme  
guoshuyu 已提交
202
<img src="./img/99.png" width="426px" height="240px"/>
G
readme  
guoshuyu 已提交
203 204

* ### 7、进度条小窗口预览
G
readme  
guoshuyu 已提交
205
<img src="./img/07.gif" height="240px"/>
S
shuyu 已提交
206

S
Shuyu Guo 已提交
207
## 五、近期版本
S
shuyu 已提交
208

G
guoshuyu 已提交
209 210 211 212 213 214

## 8.0.0 (2020-12-01)

* fix #3040 CommonUtil 获取网络信息空指针异常
* update ijk to FFMPEG 4.0

G
guoshuyu 已提交
215
## 7.1.8 (2020-10-26)
G
guoshuyu 已提交
216 217 218 219

* update support exoplayer 2.12.1
* fix #3016、[#3009](https://github.com/CarGuo/GSYVideoPlayer/issues/3009)

G
guoshuyu 已提交
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249

## 7.1.6 (2020-09-08)

* fix #2922 deprecated SkipSSLChain ,support api custom dataSource
* 因为忽略证书会导致一些 Google Play 的审核问题所以改为自定义支持
* 如果需要使用 SkipSSLChain ,可以参考 demo 里面的 exosource
* 另外通过 getHttpDataSourceFactory 也可以自定义需要的 HttpDataSource 逻辑

```
ExoSourceManager.setExoMediaSourceInterceptListener(new ExoMediaSourceInterceptListener() {
    @Override
    public MediaSource getMediaSource(String dataSource, boolean preview, boolean cacheEnable, boolean isLooping, File cacheDir) {
        //如果返回 null,就使用默认的
        return null;
    }

    /**
     * 通过自定义的 HttpDataSource ,可以设置自签证书或者忽略证书
     * demo 里的 GSYExoHttpDataSourceFactory 使用的是忽略证书
     * */
    @Override
    public HttpDataSource.BaseFactory getHttpDataSourceFactory(String userAgent, @Nullable TransferListener listener, int connectTimeoutMillis, int readTimeoutMillis, boolean allowCrossProtocolRedirects) {
        //如果返回 null,就使用默认的
        return new GSYExoHttpDataSourceFactory(userAgent, listener,
                connectTimeoutMillis,
                readTimeoutMillis, allowCrossProtocolRedirects);
    }
});
```

S
shuyu 已提交
250
### 非 androidx 版本为 6.0.3 以下版本。更多兼容版本请查阅版本更新。
G
guoshuyu 已提交
251

G
readme  
guoshuyu 已提交
252
### 更多版本请查阅:[版本更新说明](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/UPDATE_VERSION.md)
S
readme  
shuyu 已提交
253

S
Shuyu Guo 已提交
254
## 六、关于Issues
S
shuyu 已提交
255 256 257 258 259 260 261 262 263 264 265 266

```
提问题前可先查阅上方文档和说明,请在Demo中复现问题。

问题说明:

1、说明那个Demo中哪个页面。
2、问题显现和重现步骤。
3、补充问题的视频流url,截图。
4、补充问题的机型,android版本。
```

S
Shuyu Guo 已提交
267
## 七、混淆
S
shuyu 已提交
268

S
shuyu 已提交
269
```
G
guoshuyu 已提交
270 271 272 273 274 275
-keep class com.shuyu.gsyvideoplayer.video.** { *; }
-dontwarn com.shuyu.gsyvideoplayer.video.**
-keep class com.shuyu.gsyvideoplayer.video.base.** { *; }
-dontwarn com.shuyu.gsyvideoplayer.video.base.**
-keep class com.shuyu.gsyvideoplayer.utils.** { *; }
-dontwarn com.shuyu.gsyvideoplayer.utils.**
S
shuyu 已提交
276 277
-keep class tv.danmaku.ijk.** { *; }
-dontwarn tv.danmaku.ijk.**
G
guoshuyu 已提交
278 279 280 281 282 283 284 285

-keep public class * extends android.view.View{
    *** get*();
    void set*(***);
    public <init>(android.content.Context);
    public <init>(android.content.Context, android.util.AttributeSet);
    public <init>(android.content.Context, android.util.AttributeSet, int);
}
S
todo  
shuyu 已提交
286
```
287

S
Shuyu Guo 已提交
288 289
## 温馨提示

S
Shuyu Guo 已提交
290 291
#### [如果克隆太慢,可尝试从码云地址下载](https://gitee.com/CarGuo/GSYVideoPlayer)

S
Shuyu Guo 已提交
292 293 294 295 296 297 298 299 300 301 302 303 304 305
```
关于自定义和出现问题的请先看问题集锦、demo、issue。

多了解一些音视频的基础常识,对容器,音视频编码,ffmpeg先做一些了解,以及mediacodec等的不同。
尽量少出现为什么别的能播的问题哟。

播放器的可自定义还是挺高的,定制请参考demo,多看源码。现在的功能有些多,demo也在不断的更新。

一些新功能和项目结构也在不断的调整。

欢迎提出问题,谢谢。

```

S
Shuyu Guo 已提交
306
## 依赖大小参考
S
Shuyu Guo 已提交
307
建议使用ndk过滤,详细参考 [参考第四条 : 4、NDK的so支持](http://www.jianshu.com/p/86e4b336c17d)
S
Shuyu Guo 已提交
308 309 310
![](https://ooo.0o0.ooo/2017/06/15/5941f343a39f5.png)


G
guoshuyu 已提交
311 312


G
readme  
guoshuyu 已提交
313 314
## 非常感谢您的支持

G
guoshuyu 已提交
315

G
readme  
guoshuyu 已提交
316 317
#### 撸码不易,如果对你有所帮助,欢迎您的赞赏

G
guoshuyu 已提交
318
![](http://img.cdn.guoshuyu.cn/thanks.jpg)
G
readme  
guoshuyu 已提交
319 320


G
guoshuyu 已提交
321

G
readme  
guoshuyu 已提交
322
### GSY新书:[《Flutter开发实战详解》](https://item.jd.com/12883054.html)上架啦:[京东](https://item.jd.com/12883054.html) / [当当](http://product.dangdang.com/28558519.html)
G
guoshuyu 已提交
323

S
Shuyu Guo 已提交
324
[![](http://img.cdn.guoshuyu.cn/WechatIMG65.jpeg)](https://item.jd.com/12883054.html)
G
guoshuyu 已提交
325 326 327 328




329 330 331 332
## License

```
请参看IJKPlayer和AndroidVideoCache相关协议。
G
readme  
guoshuyu 已提交
333 334
项目最开始是从jiecao过来的,改着改着直接重构了。
偶尔有一变量和方法名可能还有点jiaozi的影子,但是基本是一个新项目。
S
Shuyu Guo 已提交
335
```