WhiteCombinePlayer.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. //
  2. // WhiteCombinePlayer.h
  3. // WhiteSDK
  4. //
  5. // Created by yleaf on 2019/7/11.
  6. //
  7. #import <Foundation/Foundation.h>
  8. #import "WhitePlayer.h"
  9. #import <AVFoundation/AVFoundation.h>
  10. #import "WhiteVideoView.h"
  11. #import "WhiteSliderView.h"
  12. NS_ASSUME_NONNULL_BEGIN
  13. @protocol WhiteNativePlayerProtocol <NSObject>
  14. - (void)play;
  15. - (void)pause;
  16. - (BOOL)desireToPlay;
  17. - (BOOL)hasEnoughBuffer;
  18. - (CMTime)itemDuration;
  19. @end
  20. /**
  21. `WhiteCombinePlayer` 的回调。
  22. */
  23. @protocol WhiteCombineDelegate <NSObject>
  24. @optional
  25. /**
  26. 白板回放播放器或本地播放器开始缓冲回调。
  27. */
  28. - (void)combinePlayerStartBuffering;
  29. /**
  30. 白板回放播放器和本地播放器全部缓冲结束回调。
  31. */
  32. - (void)combinePlayerEndBuffering;
  33. /**
  34. 本地播放器开始缓冲回调。
  35. */
  36. - (void)nativePlayerStartBuffering;
  37. /**
  38. 本地播放器结束缓冲回调。
  39. */
  40. - (void)nativePlayerEndBuffering;
  41. /**
  42. 本地播放器播放结束回调。
  43. */
  44. - (void)nativePlayerDidFinish;
  45. /**
  46. `WhiteCombinePlayer` 播放状态发生改变回调。
  47. @param isPlaying 是否正在播放
  48. */
  49. - (void)combineVideoPlayStateChange:(BOOL)isPlaying;
  50. /**
  51. `WhiteCombinePlayer` 无法进行播放,需要重新创建 [WhiteCombinePlayer](WhiteCombinePlayer) 进行播放。
  52. @param error 错误原因
  53. */
  54. - (void)combineVideoPlayerError:(NSError *)error;
  55. /**
  56. `WhiteCombinePlayer` 加载时间范围发生改变回调。
  57. @param loadedTimeRanges 加载时间范围。
  58. */
  59. - (void)loadedTimeRangeChange:(NSArray<NSValue *> *)loadedTimeRanges;
  60. @end
  61. #pragma mark - WhiteSyncManagerPauseReason
  62. /**
  63. `WhiteCombinePlayer` 播放状态及暂停原因。
  64. */
  65. typedef NS_OPTIONS(NSUInteger, WhiteSyncManagerPauseReason) {
  66. /** 正常播放。*/
  67. WhiteSyncManagerPauseReasonNone = 0,
  68. /** 暂停,暂停原因:白板缓冲。*/
  69. WhiteSyncManagerPauseReasonWaitingWhitePlayerBuffering = 1 << 0,
  70. /** 暂停,暂停原因:音视频缓冲。*/
  71. WhiteSyncManagerPauseReasonWaitingNativePlayerBuffering = 1 << 1,
  72. /** 暂停,暂停原因:主动暂停。*/
  73. SyncManagerWaitingPauseReasonPlayerPause = 1 << 2,
  74. /** 初始状态:暂停,白板和音视频缓冲。*/
  75. WhiteSyncManagerPauseReasonInit = WhiteSyncManagerPauseReasonWaitingWhitePlayerBuffering | WhiteSyncManagerPauseReasonWaitingNativePlayerBuffering | SyncManagerWaitingPauseReasonPlayerPause,
  76. };
  77. #pragma mark - WhiteCombinePlayer
  78. /**
  79. 同步本地视频播放器与白板回放播放器的播放状态。某一个进入缓冲状态,另一个则暂停等待。
  80. */
  81. @interface WhiteCombinePlayer : NSObject
  82. @property (nonatomic, strong, readonly) AVPlayer *nativePlayer;
  83. /** 白板回放播放器。详见 [WhitePlayer](WhitePlayer)。
  84. */
  85. @property (nonatomic, strong, nullable, readwrite) WhitePlayer *whitePlayer;
  86. /** 白板回放回调。详见 [WhiteCombineDelegate](WhiteCombineDelegate)。
  87. */
  88. @property (nonatomic, weak, nullable) id<WhiteCombineDelegate> delegate;
  89. /** 白板回放的播放速率。即使暂停回放,该值也不会变为 0。详见 [WhitePlayer](WhitePlayer)。 */
  90. @property (nonatomic, assign) CGFloat playbackSpeed;
  91. /** 白板回放的暂停原因。详见 [WhiteSyncManagerPauseReason](WhiteSyncManagerPauseReason)。*/
  92. @property (nonatomic, assign, readonly) NSUInteger pauseReason;
  93. /**
  94. 初始化一个同时持有本地音视频播放器与白板回放播放器的混合播放器对象。
  95. @param nativePlayer 本地视频播放器。
  96. @param replayer 白板回放播放器。详见 [WhitePlayer](WhitePlayer)。
  97. @return 初始化的 `WhiteCombinePlayer` 对象。
  98. */
  99. - (instancetype)initWithNativePlayer:(AVPlayer *)nativePlayer whitePlayer:(WhitePlayer *)replayer;
  100. /**
  101. 指定媒体资源地址并初始化混合播放器。
  102. @param mediaUrl 媒体资源地址。
  103. @param replayer 白板回放播放器。详见 [WhitePlayer](WhitePlayer)。
  104. @return 初始化的 `WhiteCombinePlayer` 对象。
  105. */
  106. - (instancetype)initWithMediaUrl:(NSURL *)mediaUrl whitePlayer:(WhitePlayer *)replayer;
  107. /**
  108. 指定媒体资源地址并初始化本地播放器(AV Player),需要在生成后,自行设置白板播放器属性。
  109. @param mediaUrl 媒体资源地址。
  110. @return 初始化的 `WhiteCombinePlayer` 对象。
  111. */
  112. - (instancetype)initWithMediaUrl:(NSURL *)mediaUrl;
  113. /**
  114. 初始化本地视频播放器(AV Player),需要在生成后,自行设置白板播放器属性。
  115. @param nativePlayer 本地视频播放器。
  116. @return 初始化的 `WhiteCombinePlayer` 对象。
  117. */
  118. - (instancetype)initWithNativePlayer:(AVPlayer *)nativePlayer NS_DESIGNATED_INITIALIZER;
  119. /** 视频回放的持续时长。*/
  120. - (NSTimeInterval)videoDuration;
  121. /**
  122. 播放视频。
  123. */
  124. - (void)play;
  125. /**
  126. 暂停播放视频。
  127. */
  128. - (void)pause;
  129. /**
  130. 定位到视频指定位置。
  131. 定位到本地视频播放器的指定位置后,你可以调用该方法,将白板回放播放器调整到对应位置。
  132. @param time 时间长度(s)。
  133. @param completionHandler 调用结果:
  134. - `YES`:调用已经完成。
  135. - `No`:调用未完成。
  136. */
  137. - (void)seekToTime:(CMTime)time completionHandler:(void (^)(BOOL finished))completionHandler;
  138. /**
  139. 更新白板回放播放器的播放状态。
  140. 当白板回放播放器的播放状态发生变化时,White Player 会触发该回调,向你报告板回放播放器的播放状态。
  141. @param phase [WhitePlayer](WhitePlayer) 的播放状态。
  142. **Note:** 在该回调中,需要主动调用 [WhitePlayerPhase](WhitePlayerPhase) 方法,将状态同步给 [WhitePlayer](WhitePlayer)。
  143. */
  144. - (void)updateWhitePlayerPhase:(WhitePlayerPhase)phase;
  145. @end
  146. NS_ASSUME_NONNULL_END