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源码



  • 2019-12-04 10:47:59

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:48:18

    vue 项目资源文件 static 和 assets 不说区别直接使用?

    assets中资源会webpack构建压缩到你代码中,而static文件直接引用。 static 中长存放类包、插件等第三方的文件,assets里放属资源文件比如自己资源图片、css文件、js文件。 引入资源的方式static文件夹可以使用~/static/方式引入, assets文件夹可以使用 ~@/assets 方式引入

  • 2019-12-05 17:01:36

    Vue 结合 Axios 接口超时统一处理

    当网路慢的时候。又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助。

  • 2019-12-05 17:13:40

    JS模板工具lodash.template的简单用法

    lodash是从underscore分支的一个项目,之前我写了一篇JS模板工具underscore.template的简单用法,lodash跟underscore很相似,这也简单介绍一下lodash的template方法。 先把underscore的文章中用过的代码贴过来,把underscore的js文件换成lodash的js,其他一字不改,然后我们试试:

  • 2019-12-06 10:47:29

    date-fns日期工具的使用方法详解

    isToday() 判断传入日期是否为今天 isYesterday() 判断传入日期是否为昨天 isTomorrow() 判断传入日期是否为 format() 日期格式化 addDays() 获得当前日期之后的日期 addHours() 获得当前时间n小时之后的时间点 addMinutes() 获得当前时间n分钟之后的时间 addMonths() 获得当前月之后n个月的月份 subDays() 获得当前时间之前n天的时间 subHours() 获得当前时间之前n小时的时间 subMinutes() 获得当前时间之前n分钟的时间 subMonths() 获得当前时间之前n个月的时间 differenceInYears() 获得两个时间相差的年份 differenceInWeeks() 获得两个时间相差的周数 differenceInDays() 获得两个时间相差的天数 differenceInHours() 获得两个时间相差的小时数 differenceInMinutes() 获得两个时间相差的分钟数

  • 2019-12-06 10:49:39

    npm 查看源 换源

    npm,cnpm,查看源,切换源,npm config set registry https://registry.npmjs.org

  • 2019-12-06 11:01:31

    npm发布包流程详解 有demo

    npm发布包步骤,以及踩过的坑(见红颜色标准): 1.注册npm账号,并完成Email认证(否则最后一步提交会报Email错误) 2.npm添加用户或登陆:npm adduser 或 npm login

  • 2019-12-06 13:16:18

    vue mixins组件复用的几种方式

    最近在做项目的时候,研究了mixins,此功能有妙处。用的时候有这样一个场景,页面的风格不同,但是执行的方法,和需要的数据非常的相似。我们是否要写两种组件呢?还是保留一个并且然后另个一并兼容另一个呢? 不管以上那种方式都不是很合理,因为组件写成2个,不仅麻烦而且维护麻烦;第二种虽然做了兼容但是页面逻辑造成混乱,必然不清晰;有没有好的方法,有那就是用vue的混合插件mixins。混合在Vue是为了提出相似的数据和功能,使代码易懂,简单、清晰。