媒体资源打开
open:startPos:
打开媒体资源。
- (int)open:(NSString *)url startPos:(NSInteger)startPos;
媒体播放器支持的格式详见媒体播放器。
该方法为异步调用。
调用时机
加入频道前后均可调用。
调用限制
无。
相关回调
调用该方法后会触发 AgoraRtcMediaPlayer:didChangedToState:reason: 回调。在收到报告播放状态为 AgoraMediaPlayerStateOpenCompleted 后,你可以调用 play 方法播放媒体文件。
参数
- url
- 设置媒体文件的路径,支持本地和在线文件。
- startPos
- 设置起始播放位置(毫秒),默认值为 0。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
openWithMediaSource:
打开媒体资源并进行播放设置。
- (int)openWithMediaSource:(AgoraMediaSource *)source;
该方法支持你打开不同类型的媒体资源,包括以 ipod-library://
开头的文件、以及其他自定义的媒体资源文件,并可进行播放设置。
媒体播放器支持的格式详见媒体播放器。
调用时机
该方法在加入频道前后均可调用。
调用限制
该方法为异步调用。如需播放媒体文件,需要在收到 AgoraRtcMediaPlayer:didChangedToState:reason: 回调报告状态为 AgoraMediaPlayerStateOpenCompleted 后再调用 play 方法播放媒体文件。
参数
- source
- 媒体资源,详见 AgoraMediaSource。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
preloadSrc:startPos:
预加载媒体资源。
- (int)preloadSrc:(NSString *)src startPos:(int)startPos;
详情
你可以调用该方法将一个媒体资源预加载到播放列表中。如果需要预加载多个媒体资源,你可以多次调用该方法。
调用该方法后,如果收到 AgoraRtcMediaPlayer:didPreloadEvent: 回调报告事件 AgoraMediaPlayerPreloadEventComplete,则预加载成功;如果你收到 AgoraRtcMediaPlayer:didPreloadEvent: 回调报告事件 AgoraMediaPlayerPreloadEventError,则预加载失败。
预加载成功后,如果你想播放媒体资源,请调用 playPreloadedSrc:;如果你想清空播放列表,请调用 stop。
- 调用该方法前,请确保你已经调用 open:startPos: 或 openWithMediaSource: 成功打开媒体资源。
- SDK 不支持你预加载重复的媒体资源到播放列表,但支持你将正在播放的媒体资源再次预加载到播放列表。
参数
- src
- 媒体资源的网络路径。
- startPos
- 预加载到播放列表后,开始播放时的起始位置(毫秒)。预加载直播流时,将该参数设置为 0。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
switchSrc:syncPts:
切换媒体资源。
- (int)switchSrc:(NSString *)src syncPts:(BOOL)sync;
详情
- 在网络较差时,将播放的媒体资源切换为较低码率的媒体资源地址。
- 在网络较好时,将播放的媒体资源切换为较高码率的媒体资源地址。
调用该方法后,如果你收到 AgoraRtcMediaPlayer:didOccurEvent:elapsedTime:message: 回调报告事件 AgoraMediaPlayerEventSwitchComplete,则媒体资源切换成功;如果你收到 AgoraRtcMediaPlayer:didOccurEvent:elapsedTime:message: 回调报告事件 AgoraMediaPlayerEventSwitchError,则媒体资源切换失败。
- 请确保在 open:startPos: 之后调用该方法。
- 为保证播放正常,请在调用该方法时注意如下:
- 不要在播放暂停时调用该方法。
- 不要在切换码率过程中调用 seekToPosition:。
- 确保切换码率前的播放位置不大于待切换的媒体资源总时长。
参数
- src
- 媒体资源的网络路径。
- syncPts
- 是否同步切换前后的起始播放位置:
YES
:同步。NO
:(默认) 不同步。
如果媒体资源为直播流,你只能将该参数设置为
NO
,否则 SDK 切换媒体资源会失败。如果媒体资源为点播流,你可以根据场景需求对该参数赋值。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。