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-04-17 09:41:47

    前端css博客推荐

    这个博客有大量的css内容,有svg,TweenMax等教程,抽空通读一下

  • 2020-04-17 10:20:47

    GreenSocks Animation Platform详细工作机制以及TweenMax用法

    GSAP(GreenSocks Animation Platform)是一个性能较好的前端动画库。最近在写一个前端SVG动画编辑器时选择了它作为底层的动画库。为了减少踩坑,我大致浏览了它的源代码,这篇文章主要是对我的理解进行记录。 我会先简单介绍一下这个动画库的API,再介绍它的插件机制,最后会从一个用例出发跟踪其运行机制。

  • 2020-04-17 10:39:02

    CSS 滤镜技巧与细节,实现火焰,融合等特效

    简单来说,CSS 滤镜就是提供类似 PS 的图形特效,像模糊,锐化或元素变色等功能。通常被用于调整图片,背景和边界的渲染。本文就会围绕这些滤镜展开,看看具体能怎么使用或者玩出什么花活。

  • 2020-04-17 10:42:29

    (三)TweenMax运动效果

    运动效果 实例化对象.set() 立刻运动到指定地点,不用加时间

  • 2020-04-17 11:19:55

    Vue中的is和操作DOM

    vue中is的属性引入是为了解决dom结构中对放入html的元素有限制的问题,譬如ul里面要接上li的标签,引入is的属性后,你完全可以写成这样

  • 2020-04-17 11:27:48

    TweenMax中文初级教程一

    TweenMax.js集成了GreenSock动画平台的大部分核心功能,且具有极高的兼容性。

  • 2020-04-17 11:28:35

    TweenMax中文初级教程二

    TimelineMax是GreenSock 动画平台中的动画组织、排序、管理工具,可创建时间轴(timeline)作为动画或其他时间轴的容器,这使得整个动画控制和精确管理时间变得简单,避免了通过反复delay和回调进行动画。 作者:李霖弢 链接:https://www.jianshu.com/p/8c0361e43bf5 来源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 2020-04-17 11:28:57

    TweenMax中文初级教程三

    动画关键词:CSS(一般可以省略) CSSPlugin用于在TweenMax中对DOM元素的CSS相关属性进行动画 在CSSPlugin中CSS属性需要写成驼峰式,例如font-size应当写作fontSize。有时候你可以在一些默认px为单位的属性中省略单位,CSSPlugin还可以在不同的单位间做动画:

  • 2020-04-17 11:29:23

    TweenMax中文初级教程四

    用于滚动窗口(类似于window.scrollTo(x, y))或DOM元素(如myDiv.scrollTop = y; myDiv.scrollLeft = x;)。滚动窗口时使用window作为动画目标。

  • 2020-04-17 14:06:29

    图片解释EaseIn,EaseOut,EaseInOut

    1.EaseIn:即缓动发生在入口处,也就是刚开始的时候。 2.EaseOut:即缓动发生在出口处,也就是结束之前。 3.EaseInOut:就是两边都有缓动了.