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

G
readme  
guoshuyu 已提交
2
![](https://github.com/CarGuo/GSYVideoPlayer/blob/master/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 7
> ## [如果克隆太慢,可尝试从码云地址下载](https://gitee.com/CarGuo/GSYVideoPlayer)

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 21 22
**窗口**|**小窗口、多窗体下(包括桌面)的小窗口播放。**
**广告**|**片头广告、跳过广告支持、中间插入广告功能。**
**更多**|**暂停前后台切换不黑屏;调整不同清晰度的支持;无缝切换支持;锁定/解锁全屏点击功能;进度条小窗口预览(测试)。**
**自定义**|**可自定义渲染层、自定义管理层、自定义播放层(控制层)、自定义缓存层。**
G
readme  
guoshuyu 已提交
23

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

S
Shuyu Guo 已提交
29 30 31 32 33 34
[]()
[![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)

S
Shuyu Guo 已提交
35
### [-----------------微信赞赏链接-----------------](https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/thanks.jpg)
G
readme  
guoshuyu 已提交
36

S
Shuyu Guo 已提交
37
### [--------------Demo APK 下载地址---------------](https://github.com/CarGuo/GSYVideoPlayer/releases)
S
Shuyu Guo 已提交
38

S
Shuyu Guo 已提交
39
## 一、使用依赖
S
readme  
shuyu 已提交
40

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

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

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

S
shuyu 已提交
47
#### A、直接引入
S
shuyu 已提交
48
```
S
shuyu 已提交
49
//完整版引入
G
readme  
guoshuyu 已提交
50
implementation 'com.shuyu:GSYVideoPlayer:7.1.2'
S
readme  
shuyu 已提交
51

S
shuyu 已提交
52 53
```

S
shuyu 已提交
54
#### B、添加java和你想要的so支持:
55 56

```
G
readme  
guoshuyu 已提交
57
implementation 'com.shuyu:gsyVideoPlayer-java:7.1.2'
58

G
guoshuyu 已提交
59
//是否需要ExoPlayer模式
G
readme  
guoshuyu 已提交
60
implementation 'com.shuyu:GSYVideoPlayer-exo2:7.1.2'
G
guoshuyu 已提交
61 62

//根据你的需求ijk模式的so
G
readme  
guoshuyu 已提交
63 64 65 66 67
implementation 'com.shuyu:gsyVideoPlayer-armv5:7.1.2'
implementation 'com.shuyu:gsyVideoPlayer-armv7a:7.1.2'
implementation 'com.shuyu:gsyVideoPlayer-arm64:7.1.2'
implementation 'com.shuyu:gsyVideoPlayer-x64:7.1.2'
implementation 'com.shuyu:gsyVideoPlayer-x86:7.1.2'
68 69 70

```

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

S
Shuyu Guo 已提交
73 74
A、B普通版本支持263/264/265等,对于mpeg编码会有声音无画面情况。
C 引入的so支持mpeg编码和其他补充协议,但是so包相对变大。
75 76
 
```
G
readme  
guoshuyu 已提交
77
implementation 'com.shuyu:gsyVideoPlayer-java:7.1.2'
G
guoshuyu 已提交
78 79

//是否需要ExoPlayer模式
G
readme  
guoshuyu 已提交
80
implementation 'com.shuyu:GSYVideoPlayer-exo2:7.1.2'
81

G
guoshuyu 已提交
82
//更多ijk的编码支持
G
readme  
guoshuyu 已提交
83
implementation 'com.shuyu:gsyVideoPlayer-ex_so:7.1.2'
84 85 86

```

87 88 89 90 91 92 93 94 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 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141
#### D、代码中的全局切换支持(更多请参看下方文档和demo)

```

//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;



//切换绘制模式
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 已提交
142
### [--- 更多依赖方式请点击 - ](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/DEPENDENCIES.md)
S
Shuyu Guo 已提交
143

S
Shuyu Guo 已提交
144
## 二、其他推荐
S
Shuyu Guo 已提交
145

S
Shuyu Guo 已提交
146
### * QQ群,有兴趣的欢迎(平时吹水吐槽多,因为人数饱和,目前开启付费入群):174815284 。
S
Shuyu Guo 已提交
147
### * [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 已提交
148
### * [RxFFmpeg Android 的音视频编辑工具](https://github.com/microshow/RxFFmpeg)
S
Shuyu Guo 已提交
149 150
### * [RickText](https://github.com/CarGuo/RickText)
### * [LazyRecyclerAdapter](https://github.com/CarGuo/LazyRecyclerAdapter)
S
Shuyu Guo 已提交
151

S
Shuyu Guo 已提交
152

S
Shuyu Guo 已提交
153
## 三、文档Wiki
S
readme  
shuyu 已提交
154

G
readme  
guoshuyu 已提交
155 156
文档 | 传送门
-------- | ---
G
guoshuyu 已提交
157
**使用说明**|***[--- 简单使用,快速上手文档](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/USE.md)***
S
Shuyu Guo 已提交
158
**项目解析说明**|***[--- 项目解析说明、包含项目架构和解析](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/GSYVIDEO_PLAYER_PROJECT_INFO.md)***
G
readme  
guoshuyu 已提交
159
接口文档入口|**[--- 使用说明、接口文档 - 入口](https://github.com/CarGuo/GSYVideoPlayer/wiki)**
S
Shuyu Guo 已提交
160
**问题集锦入口**|***[--- 问题集锦 - 入口(大部分你遇到的问题都在这里解决) ](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/QUESTION.md)***
G
guoshuyu 已提交
161
编码格式|**[--- IJK so文件配置格式说明](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/DECODERS.md)**
G
readme  
guoshuyu 已提交
162 163 164
编译自定义SO|**[--- IJKPlayer编译自定义SO - 入口](http://www.jianshu.com/p/bd289e25d272)**
版本更新说明|**[--- 版本更新说明 - 入口](https://github.com/CarGuo/GSYVideoPlayer/blob/master/doc/UPDATE_VERSION.md)**

S
readme  
shuyu 已提交
165

G
readme  
guoshuyu 已提交
166
![框架图](https://raw.githubusercontent.com/CarGuo/GSYVideoPlayer/master/img/StructureChart2.jpg)
G
guoshuyu 已提交
167

S
Shuyu Guo 已提交
168
## 四、运行效果
S
readme  
shuyu 已提交
169

S
Shuyu Guo 已提交
170
* ### 1、打开一个播放(旋转、镜像、填充)
G
readme  
guoshuyu 已提交
171
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/11.gif" width="240px" height="426px"/>
S
1.1.5  
shuyu 已提交
172

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

<div>
G
readme  
guoshuyu 已提交
176 177 178
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/22.gif" width="240px" height="426px"/>
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/33.gif" width="240px" height="426px"/>
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/44.gif" width="240px" height="426px"/>
S
Shuyu Guo 已提交
179
</div>
S
shuyu 已提交
180

S
shuyu 已提交
181
* ### 3、弹幕
G
readme  
guoshuyu 已提交
182
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/55.gif" width="240px" height="426px"/>
S
shuyu 已提交
183

G
guoshuyu 已提交
184
* ### 4、滤镜和GL动画
G
readme  
guoshuyu 已提交
185
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/09.gif"/>
G
guoshuyu 已提交
186

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

G
readme  
guoshuyu 已提交
189
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/99.png" width="426px" height="240px"/>
G
readme  
guoshuyu 已提交
190 191

* ### 7、进度条小窗口预览
G
readme  
guoshuyu 已提交
192
<img src="https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/07.gif" height="240px"/>
S
shuyu 已提交
193

S
Shuyu Guo 已提交
194
## 五、近期版本
S
shuyu 已提交
195

G
guoshuyu 已提交
196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218

### 7.1.2(2019-12-02)

* fix #2436 增加 exo 的 http timeout 
```
ExoSourceManager

 public static void setHttpReadTimeout(int httpReadTimeout)
 
 public static void setHttpConnectTimeout(int httpConnectTimeout)

```
* 优化视频尺寸显示计算 
* 增加 exo 支持 raw 文件播放

``` 
String url =  RawResourceDataSource.buildRawResourceUri(R.raw.test).toString();
```
* 增加模拟下载共用缓存例子 DetailDownloadPlayer
* 适配 android 10 的全屏
* fix #2382、#2411、#2343、#2379、#2350、#2328


G
guoshuyu 已提交
219 220 221 222 223 224 225 226 227 228 229 230 231
### 7.1.1(2019-10-12)

* fix #2244、#2252(resolveFullVideoShow 不执行情况)、#2279、#2280
* fix #2303(去除 TimerTask)、#2306(某些机型退到后台返回不显示)
* 增加 setNeedAutoAdaptation
```
    /**
     * 是否需要适配在竖屏横屏时,由于刘海屏或者打孔屏占据空间,导致标题显示被遮盖的问题
     *
     * @param needAutoAdaptation 默认false
     */
    public void setNeedAutoAdaptation(boolean needAutoAdaptation)
```
S
shuyu 已提交
232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254

### 7.1.0(2019-09-01)

* update ExoPlayer to 2.10.4
* 添加沉浸式支持
* 增加 IPlayerInitSuccessListener 播放器初始化成果回调
```
GSYVideoManager
    .instance()
    .setPlayerInitSuccessListener(new IPlayerInitSuccessListener() {
        ///播放器初始化成果回调,可用于播放前的自定义设置
        @Override
        public void onPlayerInitSuccess(IMediaPlayer player, GSYModel model) {
            if (player instanceof IjkExo2MediaPlayer) {
                ((IjkExo2MediaPlayer) player).setTrackSelector(new DefaultTrackSelector());
                ((IjkExo2MediaPlayer) player).setLoadControl(new DefaultLoadControl());
            }
        }
    });
```
* fix #2142
* 增加硬解码不花屏幕 [RecyclerView3Activity](https://github.com/CarGuo/GSYVideoPlayer/blob/master/app/src/main/java/com/example/gsyvideoplayer/RecyclerView3Activity.java)

S
shuyu 已提交
255

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

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

S
Shuyu Guo 已提交
260
## 六、关于Issues
S
shuyu 已提交
261 262 263 264 265 266 267 268 269 270 271 272

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

问题说明:

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

S
Shuyu Guo 已提交
273
## 七、混淆
S
shuyu 已提交
274

S
shuyu 已提交
275
```
G
guoshuyu 已提交
276 277 278 279 280 281
-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 已提交
282 283
-keep class tv.danmaku.ijk.** { *; }
-dontwarn tv.danmaku.ijk.**
G
guoshuyu 已提交
284 285 286 287 288 289 290 291

-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 已提交
292
```
293

S
Shuyu Guo 已提交
294 295
## 温馨提示

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

S
Shuyu Guo 已提交
298 299 300 301 302 303 304 305 306 307 308 309 310 311
```
关于自定义和出现问题的请先看问题集锦、demo、issue。

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

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

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

欢迎提出问题,谢谢。

```

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


G
readme  
guoshuyu 已提交
317 318 319 320
## 非常感谢您的支持

#### 撸码不易,如果对你有所帮助,欢迎您的赞赏

G
readme  
guoshuyu 已提交
321
![](https://github.com/CarGuo/GSYVideoPlayer/blob/master/img/thanks.jpg)
G
readme  
guoshuyu 已提交
322 323


324 325 326 327
## License

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