当前位置:首页 > 通信资讯 > 正文

直播视频iOS(直播ios直播)

对于直播来说,客户端主要做两件事情,推流和播放。今天先讲播放。

播放流程

  1. 拉流:服务器已有直播内容,从指定地址进行拉取的过程。其实就是向服务器请求数据。
  2. 解码:对视屏数据进行解压缩。
  3. 渲染:生成图片的过程。视屏其实就是一张张连续的图片进行切换,一张图片就是一帧。帧率顾名思义就是每秒显示的图片数,当帧率达到16时,人眼就会认为是流畅的。是不是很神奇。

这里的每个步骤能弄明白都可以成为人才了,如果还能解决其中的不足,那你就是尖端人才了。弄懂这些需要耗费大量的时间,还好有ijkplayer视屏直播框架,有了它,即时你不懂这些过程,也可以进行直播播放,大神真多。

ijkplayer视屏直播框架

ijkplayer视屏直播框架下载地址,这是开源的,喜欢研究源码的同学可以去下载,,基于ffmpeg,同时支持ios和android,非常强大。上述的三个过程它全给你做好了,只要你集成到自己工程里,就能实现播放直播了。

&emsp ;集成到自己的工程中,最好先打包,我这里用打包好的debug模式下的,怎么集成的,同学们可以去看这篇文章《详解ios中集成ijkplayer视频直播框架》。和导入第三方库一样,导入到自己工程中,同时还要添加依赖的动态库。

直播视频iOS(直播ios直播)

直播

直播视频iOS(直播ios直播)

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 #import "fhliveviewcontroller.h" #import <ijkmediaframework/ijkmediaframework.h> #import <uiimageview+webcache.h> // ijk下载地址: https://pan.baidu.com/s/1c2p9d0s @interface fhliveviewcontroller () // 播放器 @property (nonatomic, strong) ijkffmovieplayercontroller *playervc; @end @implementation fhliveviewcontroller - (void)viewdidload { [super viewdidload]; // 隐藏导航栏 [self.navigationcontroller.navigationbar sethidden:yes]; // 设置背景色 [self.view setbackgroundcolor:[uicolor whitecolor]]; // 拉流地址 nsurl *url = [nsurl urlwithstring:self.liveurl]; // 实例化播放器,传入拉流地址即可 _playervc = [[ijkffmovieplayercontroller alloc] initwithcontenturl:url withoptions:nil]; // 准备播放 准备好了自动播放 [_playervc preparetoplay]; // 设置播放器尺寸 _playervc.view.frame = [[uiscreen mainscreen] bounds]; [self.view addsubview:_playervc.view]; // 设置填充模式:铺满 [_playervc setscalingmode:ijkmpmoviescalingmodeaspectfill]; } - (void)viewwilldisappear:(bool)animated{ [super viewwilldisappear:animated]; // 关闭播放时,要停止播放器,否则会崩溃 [_playervc pause]; [_playervc stop]; }

就这么几行代码,播放就实现了我们仅仅是传了一个拉流地址。这个框架简直是太强大了,自动帮我们完成了拉流、解码、渲染,我们什么都不用做,b站的工程师真是很

如果您对该产品感兴趣,请填写办理(客服微信:xiaoxiongyidong)

为您推荐:

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。