3_2-云课堂场景-播放器

1 功能概述

视频播放是多场景项目中提供的基础功能,功能包括直播播放器和回放播放器,在云课堂场景模块中播放器主要功能代码在PLVLCMediaAreaView中,PLVLCMediaAreaView集成7_3 核心common-播放器PLVPlayerPresenter来实现的功能。

2 初始化及播放

代码如下:

/// PLVLCMediaAreaView.m

- (void)setupModule{
    if (self.videoType == PLVChannelVideoType_Live) {
        /// 初始化直播 模块
        self.playerPresenter = [[PLVPlayerPresenter alloc] initWithVideoType:PLVChannelVideoType_Live];
        self.playerPresenter.delegate = self;
        [self.playerPresenter setupPlayerWithDisplayView:self.canvasView.playerSuperview];
        
    }else if (self.videoType == PLVChannelVideoType_Playback){
        /// 初始化直播回放 模块
        self.playerPresenter = [[PLVPlayerPresenter alloc] initWithVideoType:PLVChannelVideoType_Playback];
        self.playerPresenter.delegate = self;
        [self.playerPresenter setupPlayerWithDisplayView:self.canvasView.playerSuperview];
    }
}

3 播放器皮肤

云课堂场景播放器部分功能是通过皮肤UI的代理回调来控制的,皮肤分为竖屏皮肤PLVLCMediaPlayerSkinView和横屏皮肤PLVLCLiveRoomPlayerSkinView,两种皮肤都基于PLVLCBasePlayerSkinView扩展而来,横竖屏皮肤UI元素是一样的区别在于UI布局不同。

3.1 皮肤控制播放器

  • 直播:刷新按钮、直播时长、全屏按钮

  • 回放:播放器播放时间、总时间、进度条、全屏按钮

3.2 皮肤代理回调

横屏皮肤的代理全部定义在几类PLVLCBasePlayerSkinView 中,具体回调到外部,功能业务不同在不同地方调用回调

  • 点击返回

    实现处理功能:

    • 全屏时将房间改变成竖屏;

    • 竖屏时退出房间;

  • 点击更多

    实现处理功能:打开更多视图,更多功能参考4 播放器更多

  • 点击播放、暂停

    实现处理功能:播放、暂停播放器

  • 点击刷新

    实现处理功能:重新加载直播视频内容

  • 拖动进度条

    实现处理功能:改变回放播放器播放进度

3.3 竖屏皮肤PLVLCMediaPlayerSkinView

PLVLCMediaPlayerSkinView对象在PLVLCMediaAreaView.m中与PLVPlayerPresenter交互,,通过PLVLCMediaAreaView的代理与PLVLCCloudClassViewController交互,同步横屏皮肤UI状态。

3.4 横屏皮肤PLVLCLiveRoomPlayerSkinView

PLVLCLiveRoomPlayerSkinView 对象在PLVLCCloudClassViewController.m中与PLVLCMediaAreaView交互,达到控制PLVPlayerPresenter和同步竖屏皮肤目的。

PLVLCBasePlayerSkinViewPLVLCMediaPlayerSkinViewPLVLCLiveRoomPlayerSkinView可以在polyv demo项目中找到。

4 播放器更多

云课堂场景播放器切换视频或音频、视频质量(码率)和线路功能是在PLVLCMediaAreaView.m中通过PLVPlayerPresenter和UI封装类PLVLCMediaMoreView实现切换播放器质量线路功能。

  • 初始化更多视图,同步播放器状态

  • 实现更多代理回调,控制播放器

PLVLCMediaMoreView可以在polyv demo项目中找到。

5 播放器画布

云课堂场景播放器画布是根据房间状态(暂无直播、等待直播、直播中、直播断开、直播结束)和播放器模式(视频、音频),显示相对应UI和通过代理回调控制播放器,此功能UI封装在PLVLCMediaPlayerCanvasView中,在PLVLCMediaAreaView.m中实例化和调用。

实现PLVLCMediaPlayerCanvasViewDelegate代理

在音频模式下,点击播放画面回调此方法,在PLVLCMediaPlayerCanvasView中处理回调,播放器切换为视频模式

PLVLCMediaPlayerCanvasView可以在polyv demo项目中找到。

Last updated

Was this helpful?