| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- //
- // KSYMediaPlayback.h
- // KSYMediaPlayback
- //
- // Created by zengfanping on 10/12/15.
- // Copyright © 2015 kingsoft. All rights reserved.
- //
- #import <MediaPlayer/MediaPlayer.h>
- /*!
- KSYMediaPlayback为播放内核[KSYMoviePlayerController](KSYMoviePlayerController)提供播放控制功能。
-
- ## 联系我们
- 当本文档无法帮助您解决在开发中遇到的具体问题,请通过以下方式联系我们,金山云工程师会在第一时间回复您。
-
- __E-mail__: zengfanping@kingsoft.com
-
- */
- @protocol KSYMediaPlayback
- /**
- @abstract 准备视频播放
- @discussion prepareToPlay处理逻辑
- * 如果isPreparedToPlay为FALSE,直接调用[play]([KSYMediaPlayback play]),则在play内部自动调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])接口。
- * prepareToPlay调用后,由MPMediaPlaybackIsPreparedToPlayDidChangeNotification通知完成准备工作。查询[isPreparedToPlay]([KSYMediaPlayback isPreparedToPlay])可以获得具体属性值。
- @discussion 通知类型
-
- * MPMediaPlaybackIsPreparedToPlayDidChangeNotification, 播放器完成对视频文件的初始化时发送通知
-
- @see isPreparedToPlay
- */
- // Prepares the current queue for playback, interrupting any active (non-mixible) audio sessions.
- // Automatically invoked when -play is called if the player is not already prepared.
- - (void)prepareToPlay;
- /**
- @abstract 查询视频准备是否完成
- @discussion isPreparedToPlay处理逻辑
-
- * 如果isPreparedToPlay为TRUE,则可以调用[play]([KSYMediaPlayback play])接口开始播放;
- * 如果isPreparedToPlay为FALSE,则需要调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])接口开始准备工作;
- * 如果isPreparedToPlay为FALSE,直接调用[play]([KSYMediaPlayback play]),则在play内部自动调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])接口。
- @see prepareToPlay
- */
- // Returns YES if prepared for playback.
- @property(nonatomic, readonly) BOOL isPreparedToPlay;
- /**
- @abstract 播放当前视频。
- @discussion play的使用逻辑:
-
- * 如果调用play方法前已经调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])完成播放器对视频文件的初始化,且[shouldAutoplay]([KSYMoviePlayerController shouldAutoplay])属性为NO,则调用play方法将开始播放当前视频。此时播放器状态为CBPMoviePlaybackStatePlaying。
- * 如果调用play方法前已经调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])完成播放器对视频文件的初始化,且[shouldAutoplay]([KSYMoviePlayerController shouldAutoplay])属性为YES,则调用play方法将暂停播放当前视频,实现效果和pause一致。
- * 如果调用play方法前未调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])完成播放器对视频文件的初始化,则播放器自动调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])进行视频文件的初始化工作。
- * 如果调用play方法前已经调用pause暂停了正在播放的视频,则重新开始启动播放视频。
- @since Available in KSYMediaPlayback 1.0 and later.
- @see prepareToPlay
- */
- // Plays items from the current queue, resuming paused playback if possible.
- - (void)play;
- /**
- @abstract 暂停播放当前视频。
- @discussion pause调用逻辑:
-
- * 如果当前视频播放已经暂停,调用该方法将不产生任何效果。
- * 重新回到播放状态,需要调用[play]([KSYMediaPlayback play])方法。
- * 如果调用pause方法后视频暂停播放,此时播放器状态处于CBPMoviePlaybackStatePaused。
- * 播放器内部监听了UIApplicationWillEnterForegroundNotification通知,该通知发生时如果视频仍然在播放,将自动调用pause暂停当前视频播放。
-
-
-
- @discussion 后台播放逻辑:
-
- * 需要APP有后台执行权限,在工程Info.plist中添加后台运行模式,设置为audio。具体是添加UIBackgroundModes项,值为audio。
- * 当用户点击home按钮后,播放器进入后台继续读取数据并播放音频。
- * 当APP回到前台后,音频继续播放。图像渲染内容保持和音频同步。
- * 如果在开启后台运行模式后,需要切换后台暂停,需要监听相关事件并主动调用pause操作。
-
- @since Available in KSYMediaPlayback 1.0 and later.
- */
- // Pauses playback if playing.
- - (void)pause;
- /**
- @abstract 结束当前视频的播放。
- @discussion stop调用逻辑:
-
- * 调用stop结束当前播放,如果需要重新播放该视频,需要调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])方法。
- * 调用stop方法后,播放器开始进入关闭当前播放的操作,操作完成将发送MPMoviePlayerPlaybackDidFinishNotification通知。
-
- @discussion 通知:
-
- * MPMoviePlayerPlaybackDidFinishNotification, 当播放完成将发送该通知。
-
- @since Available in KSYMediaPlayback 1.0 and later.
- @see prepareToPlay
- */
- // Ends playback. Calling -play again will start from the beginnning of the queue.
- - (void)stop;
- /**
- @abstract 播放视频的当前时刻,单位为秒。
- @discussion currentPlaybackTime属性更改时机:
-
- * 视频正常播放时,如果改变currentPlaybackTime的值,将导致播放行为跳转到新的currentPlaybackTime位置播放。
- * 在调用[prepareToPlay]([KSYMediaPlayback prepareToPlay])之前设置该属性的值无效,若希望从指定位置开始播放,需要以下设置
- * 将player的自动播放属性shouldAutoplay设置为NO;
- * 监听到MPMediaPlaybackIsPreparedToPlayDidChangeNotification通知时,将currentPlaybackTime设置为期望开始播放的时间点,单位是秒
- * 调用play方法,即可从指定位置开始播放
- @since Available in KSYMediaPlayback 1.0 and later.
- */
- // The current playback time of the now playing item in seconds.
- @property(nonatomic) NSTimeInterval currentPlaybackTime;
- @end
|