doc/GSYVIDEO_PLAYER_PROJECT_INFO.md
Click to see the English version
目前整个video层即是传统controller层,也是大部分时候自定义实现需要继承的层
* 管理层GSVideoManager继承GSYVideoBaseManager,通过IPlayerManager控制播放内核。
* 管理层GSVideoManager实现了GSYVideoViewBridge,和UI层交互(主要通过UI层的GSYVideoPlayer)。
* Cache层主要是对缓存的实现和管理,目前有通用的代理缓存,与exo的CacheDataSourceFactory。
* UI层GSYTextureRenderView通过GSYRenderView,内置IGSYRenderView实现类,和渲染层交互。
* UI层逐层继承实现各层逻辑,内部大部分方法为protect。
从这里看出,项目的播放内核、管理器、渲染层都是可以自定义替换的。
近期新增和调整的播放能力,可以按下面方式理解:
| 能力 | 所在层级 | 说明 |
|---|---|---|
| 通用外挂字幕 | Video/UI 层 | GSYSubtitleController 和 GSYSubtitleView 根据播放器进度渲染 SRT/WebVTT,加载失败不影响主视频。 |
| WebVTT 进度条预览 | Demo + Preview Provider | PreViewGSYVideoPlayer 消费 GSYVideoPreviewProvider,缩略图和 sprite 坐标由业务侧或服务端提供。 |
| 截图 | Render + Video 层 | Render 层负责取视频帧,StandardGSYVideoPlayer 新增组合截图 API,用于叠加播放器 UI。 |
| GLSurfaceView 效果 | Render 层 | GL renderer 负责滤镜、纹理、截图和 release,Demo 退出时恢复原全局 render type。 |
| 多 URL 清晰度切换 | Video + Manager 层 | SmartPickVideo 使用临时 manager 预加载新 URL,seek 同步后提交,失败时回退原播放。 |
| Exo 自适应清晰度 | Exo Manager 层 | HLS master / DASH MPD 走单个媒体时间线,Media3 TrackSelector 自动选轨,固定清晰度使用 TrackSelectionOverride。 |
| 完成后保留最后一帧 | Demo Video 层 | KeepLastFrameVideo 只作为业务语义验证,不改变基础播放器默认完成态。 |
| 播放器初始化失败处理 | Manager + Player 层 | GSYVideoBaseManager 和各 IPlayerManager 将内核创建/初始化异常收敛到错误回调和资源清理。 |
| Exo cache 与 GIF 清理 | Cache + Utils 层 | ExoSourceManager 管理 Exo cache 生命周期,GifCreateHelper 负责 GIF 生成状态和临时资源清理。 |
更完整的入口、API、回归清单见 RECENT_FEATURES.md。
项目目前内部主要提供控制API和少量配置API: API地址。
项目目前UI层大部分方法和变量都是protect,虽然就封装性而言这并不是很好,但你可以继承后快捷实现你的自定义。
例如:
重写getLayoutId()方法,返回你的自定义布局,重用逻辑的控件只要控件Id一致即可。若需要新增控件,可重载init(Context context)方法参考源码实现,其中注意如有自定义参数,需要重载cloneParams实现大小屏同步,更甚至可以重载startWindowFullscreen和resolveNormalVideoShow,参考源码和demo,这很简单, 如Demo中: SampleCoverVideo。
如Demo中:EmptyControlVideo,重载 touchSurfaceMoveFullLogic 和 touchDoubleUp,实现了触摸相关的自定义。
同样showWifiDialog、showProgressDialog 、 showVolumeDialog等重写实现你的自定义弹窗;onClickUiToggle、changeUiTo****、OnClick、OnTouch、touchDoubleUp`等方法重载可自定义手势行为。
如上图所示,前面说过播放内核Player层、Manger层、渲染层都是可以替换的,只要实现了对应的接口,继承后替换对应的实现类,就可以替换对应层的内部实现逻辑。 例如Demo中: ListMultiVideoActivity 、CustomManager 、MultiSampleVideo 就演示了如何通过自定义Manager实现,多个播放内核同时播放的效果。
cloneParams \ resolveFullVideoShow 、 startWindowFullscreen 等方法的实现,另外外部获取记得水涌 player.getCurrentPlayer() 获取区分