ios后台播放视频

2021-01-24 10:08:57

参考地址 iOS AVPlayer之后台连续播放视频

很多开发者以为AVPlayer不能在后台播放视频:应用退到后台,但能播放视频的声音(ps:不是通过切换相同的音频来实现),我在开发SDK的过程中也遇到这个需求,所幸解决了这个问题。下面我就来讲讲实现的过程。

一 iOS和tvOS应用程序需要您启用某些后台操作的某些功能。 播放应用程序所需的常见功能是播放背景音频。 启用此功能后,当用户切换到其他应用或锁定iOS设备时,您的应用的音频可以继续。 此功能也需要在iOS中启用高级播放功能,如AirPlay流媒体和画中画播放功能。启用背景音频有两种方法: 1.在info.plist文件中添加Required background modes 如下图所示

屏幕快照 2017-09-11 上午9.45.19.png
2.工程Capabilities
屏幕快照 2017-09-11 上午10.12.49.png


二 AVPlayer的处理 如果AVPlayer的当前项目在设备的显示屏上显示视频 ,则当应用程序发送到后台时, AVPlayer播放将自动暂停。 有两种方法可以防止这种暂停: 1.禁用播放器项目中的视频轨道。这种方法仅适用本地文件,不可用于网络视频。

让playerItem = <#你的播放器项目#>  让tracks = playerItem.tracks  for trackItemTrack in tracks {  //查找视频轨道并禁用轨道  playerItemTrack.assetTrack.hasMediaCharacteristic(AVMediaCharacteristicVisual){   playerItemTrack.isEnabled = false }  } 复制代码

2.从相关的AVPlayer删除AVPlayer(将AVPlayerLayer player属性设置为nil)。这种方法不仅适用于本地视频,还适用于网络视频,重点推荐。 重要提示:这些更改必须在应用程序实际切换到后台之前生效。 否则AVPlayer将被暂停。 应用程序委托的applicationDidEnterBackground方法方便此目的。 如果禁用任何视频轨道,则当应用程序转换到前台或视频无法恢复播放时,必须重新启用这些视频轨道。 同样,您必须将任何AVPlayerLayer重新连接到AVPlayer 。 应用程序委托applicationDidBecomeActive方法方便此目的。

//已经进入后台

- (void)applicationDidEnterBackground:(UIApplication *)application {    LYAVPlayerView *playerView =[LYAVPlayerView sharedInstance];    [playerView.playerLayer setPlayer:nil]; } 复制代码

//已经激活

- (void)applicationDidBecomeActive:(UIApplication *)application {     LYAVPlayerView *playerView =[LYAVPlayerView sharedInstance];     AVPlayer *player =playerView.player;     [playerView.playerLayer setPlayer:player]; } 复制代码

播放完毕后接着在代理方法里播放下一个视频就可实现后台连续播放视频:

//播放完毕 - (void)videoPlayerDidReachEnd:(LYAVPlayerView *)playerView{           NSLog(@"播放完毕");          [self.playerView setURL:[NSURL URLWithString:VideoURL]];     [self.playerView play];      } 复制代码

GitHub源码



  • 2020-03-04 13:00:23

    NPM酷库:minimist,命令行参数解析

    昨天我们了解的dotenv库用于从文件中加载环境变量。环境变量用于程序运行时动态加载参数,除了环境变量,我们还可以在启动Node.js 程序时直接指定命令行参数:

  • 2020-03-04 21:01:26

    window自带截屏功能

    我们习惯了QQ和微信截图,当我们没有打开微信和QQ的时候,我们想用截图怎么版,当然是,打开QQ和微信,哈哈?

  • 2020-03-05 13:12:54

    Markdown的css样式

    本样式在这个样式的基础上做了一些修改, 主要是对于表格和代码块以及一些细节的修改。 主要目的是用在chrome的扩展 Markdown Preview Plus中, 替换其内置的样式。 由于 Markdown Preview Plus对css文件大大小有要求(小于8K), 所以需要使用压缩后的 css 文件。 当然也可以作为一个单独的markdown样式来使用。

  • 2020-03-06 22:28:05

    git中submodule子模块的添加、使用和删除

    执行成功后,git status会看到项目中修改了.gitmodules,并增加了一个新文件(为刚刚添加的路径) git diff --cached查看修改内容可以看到增加了子模块,并且新文件下为子模块的提交hash摘要 git commit提交即完成子模块的添加