GitHub 仓库地址

一个高度封装的视频播放器视图,基于 AVPlayer、AVPlayerLayer、AVPlayerItem。

继承自 UIView,可以当做一般视图使用,适用于 Swift 和 Objective-C。

Example

Installation

Requirements

  • Xcode 8 or higher
  • iOS 11.0 or higher
  • ARC

Cocoapods

pod 'BBPlayerView'

Manually

  1. 下载 BBPlayerView。
  2. 添加 "BBPlayerView/Resource" 文件夹到项目中。

API

  • Delegate
@class BBPlayerView;
@protocol BBPlayerViewDelegate <NSObject>
@optional /**
播放进度更新回调
当播放结束后可以决定是否循环播放
*/
- (void)bb_playerView:(nullable BBPlayerView *)playerView progressDidUpdatedAtTime:(CGFloat)currentTime totalTime:(CGFloat)totalTime progress:(CGFloat)progress; /** 播放状态变化回调 */
- (void)bb_playerView:(nullable BBPlayerView *)playerView statusDidUpdated:(BBPlayerViewStatus)status; /** 预加载进度回调 */
- (void)bb_playerView:(nullable BBPlayerView *)playerView didPreloadData:(CGFloat)startTime durationTime:(CGFloat)durationTime totalLoadedTime:(CGFloat)totalLoadedTime totalTime:(CGFloat)totalTime; @end
  • Class
@interface BBPlayerView : UIView

/**
代理
通过代理方法可以获取播放状态、播放进度、预加载进度的变化
!!!确保在调用 -bb_loadDataWithURL: 方法之前设置代理属性(如果不需要代理则不用设置)!!!
*/
@property (nonatomic, weak, nullable) IBOutlet id <BBPlayerViewDelegate> bb_delegate; /**
加载媒体资源或切换媒体资源
如果新加载的媒体资源 URL 和当前载入的 ULR 相同且播放器处于 BBPlayerViewStatusReadyToPlay 状态,则忽略本次加载操作
每次真正载入媒体资源时,都会自动调用一次 -bb_release 方法
*/
- (void)bb_loadDataWithURL:(nullable NSString *)url;
/** 清空播放器 */
- (void)bb_release; /**
播放
由于 AVPlayer 的属性 actionAtItemEnd 设置为 AVPlayerActionAtItemEndPause (默认值)
所以在媒体资源播放结束后 AVPlayer 的 rate 会设为 0.0
在媒体资源结尾处调用该方法无效(进度不变仍处在 1.0) 注意:在加载某些媒体资源时,播放结束后调用 -bb_play/-bb_pause 方法可能会改变 AVPlayer 的 rate 值为 1.0/0.0
那么再去调用 -bb_seekToProgress:completionHandler: 方法,可能在跳转成功后处于 播放/暂停 状态
所以确保媒体资源播放结束后不要调用 -bb_play/-bb_pause 方法
*/
- (void)bb_play;
/** 暂停 */
- (void)bb_pause; /// 跳转至指定进度。
/// 该方法完成后不会改变播放速率
/// 该方法是异步操作
/// @param progress 指定进度。取值范围:0.0 ~ 1.0
/// @param completionHandler 结束回调。finished 参数:YES 表示跳转完成;NO 表示跳转失败或取消了
- (void)bb_seekToProgress:(CGFloat)progress completionHandler:(void (^ _Nullable)(BOOL finished))completionHandler; /**
视频填充模式
BBPlayerViewGravityScaleFill -- 填充满视图,可能变形,内容不会缺失
BBPlayerViewGravityAspectFill -- 填充满视图,不变形,可能内容缺失
BBPlayerViewGravityAspectFit -- 不变形填充视图,直到一个边到达视图边界,内容不会缺失
*/
@property(nonatomic) BBPlayerViewGravity bb_videoGravity; @end
@interface BBPlayerViewCellManager : NSObject

@property (class, readonly) BBPlayerViewCellManager *bb_manager;

/**
添加真实播放视频的 cell
只在 cell 播放视频时把该 cell 加入到 manager 来管理
*/
- (void)addCell:(id<BBPlayerViewCellManagerDelegate>)cell; /**
移除 cell
在 cell 进入可复用状态调用
即:在 -prepareForReuse 调用该方法
*/
- (void)removeCell:(id<BBPlayerViewCellManagerDelegate>)cell; /**
移除全部 cell
在列表所在控制器销毁时调用
即:在 -dealloc 调用该方法
*/
- (void)removeAllCells; /**
所有 cell 暂停播放
指定某个 cell 播放时,其他所有 cell 暂停播放
*/
- (void)pauseAllCellPlayers; @end

Use

导入文件

  • Swift 中在需要引用的地方
import BBPlayerView
  • Objective-C 中在需要引用的地方
#import "BBPlayerView.h"

使用说明

BBPlayerView 可以像 UIView 一样代码创建或者在 xib、storyboard 拖拽创建。

详细使用方法请下载项目参考使用示例,包括简单的视频播放和视频列表播放功能。

  1. 如果不关心资源加载状态只需两行代码即可实现。
[_playerView bb_loadDataWithURL:_URLField.text];
[_playerView bb_play];
  1. 通过 BBPlayerView 提供的公开方法可以很容易实现:加载播放资源、播放、暂停、重新播放、跳转指定进度、释放资源清空播放器。
  2. 视频列表一般会保证只有一个视频在播放,所以要控制 cell 中的播放器在其他 cell 播放时暂停播放。

    BBPlayerViewCellManager 就是一个管理视频列表 cell 的管理类。

播放状态转移图片

图片中箭头表示操作或持续操作的结果,矩形表示状态。



GitHub 仓库地址

BBPlayerView的更多相关文章

随机推荐

  1. Vue style与css的var()

    vue绑定style直接给css的var变量传递一个值,然后结合css的var()函数使用这个值. 在data里面定义一个变量然后给定一个值,后期修改这个值之后,所有依赖这个变量的css样式都会被响应 ...

  2. redis为什么那么快?

    数据库有很多,为什么Redis能有如此突出的表现呢?一方面,因为它是内存数据库,所有操作都在内存上完成.另外一方面就要归功于他的数据结构.高效的数据结构是Redis快速处理的基础.今天我们就来聊聊了R ...

  3. APDU:APDU常用指令

    APDU= ApplicationProtocol data unit, 是智能卡与智能卡读卡器之间传送的信息单元, (给智能卡发送的命令)指令(ISO 7816-4规范有定义) CLA INS P1 ...

  4. 63. Unique Paths II 动态规划

    description: https://leetcode.com/problems/unique-paths/ 机器人从一堆方格的左上角走到右下角,只能往右或者往下走 ,问有几种走法,这个加了难度, ...

  5. linux挂载光驱

    挂载光驱到linux中.linux的镜像盘中有安装oracle的所有的软件包,可以会用yum一键安装. 1.此时的linux的界面显示光驱图标 2.挂载 因为光盘里面的文件是只读模式的,yum安装时不 ...

  6. win10 sql2008r2网页不能使用数据,需要开启端口1433

    1.打开sql server configuratiton Manager 2.sqlserver网络配置--SQLEXPRESS的协议:都启用 3.双击TCP/IP:选择"IP地址&quo ...

  7. python pip install matplotlib安装模块

    python pip install matplotlib安装模块,可附带安装相关的模块 程序运行提示: from . import _imaging as coreImportError: DLL ...

  8. 传统.NET 4.x应用容器化体验(3)

    上一篇我们自己通过编写Dockerfile来编译部署一个ASP.NET MVC应用程序到Windows Container,这一篇我们来试着将.NET 4.x的镜像推送到harbor私有镜像仓库. 1 ...

  9. 高校表白App-团队冲刺第二天

    今天要做什么 今天要把昨天的activity进行完善,并且加上计时跳转的功能,将其设置为主页面,设置两种跳转功能. 遇到的问题 今天没遇到什么大的问题,只是在进行编写的时候,又出现了R文件无法找到的情 ...

  10. 认识vue-cli脚手架

    ps:脚手架系列主要记录我自己(一名前端小白)对脚手架学习的一个过程,如有不对请帮忙指点一二! [抱拳] 作为一名前端开发工程师,平时开发项目大多都离不开一个重要的工具,那就是脚手架.下面让我们来了解 ...