美文网首页ios实用开发技巧iOSiOS技术相关
iOS 视频直播与录播拉流框架1.0

iOS 视频直播与录播拉流框架1.0

作者: Leesim | 来源:发表于2017-03-13 17:16 被阅读1056次

    该文章已作废,请移步最新代码

    iOS 视频直播与录播拉流框架2.0

    最近由于需求的变动,项目内把最初最简单的原生直播框架变成了B站开源的ijkplayer框架,下面把具体的过程总结一下整个过程都比较简单,重要的是理解的过程,集成完毕之后,视频的用户体验比苹果原生好了很多。最后会贴出demo的git地址,只需要简单的操作就能快速的在项目中加入该框架

    先把B站开源ijkplayer的github地址贴出来 https://github.com/Bilibili/ijkplayer
    未使用过的同学,请去自取有助于理解整个视频框架的原理。

    ** 为何要改变原来项目内的视频直播,录播框架?**

    首先我先说一下为何我们项目内会修改原来原生的直播与视频框架,这个过程能体现出来ijkplayer对比iOS原生的各种优点。

    1.我们最初使用的原声直播是使用MPMoviePlayerController,该类苹果官方有提示让使用AVPlayerViewController来替代,虽然MPMoviePlayerController就目前来看还可以正常使用,但是可能在未来不久的时间就会出现问题。
    2.对比直播:直播的第一指标是延迟问题,苹果原生的直播协议仅支持hls协议,而ijkplayer不仅支持hls,也支持rtmp协议,hsl协议的弊端就是让人头疼的延迟问题,该协议会把视频切成一段一段的m3u8的视频片段,延迟一般来说会到10秒左右,而rtmp协议延迟非常小,从修改完之后的情况来说,视频的流畅度提高了非常多。这条原因,是修改直播框架的根本原因之一。
    3.对比录播流:如果同时播放云端存储的视频流,它存在着一些不可回避的问题,那就是支持的视频编码格式很有限:H.264、MPEG-4,扩展名(压缩格式):.mp4、.mov、.m4v、.m2v、.3gp、.3g2等。这种支持对于运营的操作要求很高,支持的格式比较少。而ijkplayer不仅包括了原生可以支持的所有格式,主流的视频格式基本可以全部支持。
    4.对比用户交互:MPMoviePlayerController自定义样式和用户交互的一些手势操作非常有限,而ijkplayer你几乎可以定制一切你可以想到的交互,主流的直播app都在使用。

    对比以上几条原因,我们在项目中进行了进一步的升级,使用ijkplayer的需求非常迫切。

    ** 主要代码相关**

    具体demo会在下方贴出链接,这里仅演示最重要的几步要求。

    1.下载完毕demo后,由于ijk的framework包比较大所以没有跟着项目一起上传,需要先将github地址详情内的ijk的framework的zip包下载下来,导入项目,并且将路径配置好。

    其实打出来ijk的framework包的这个过程是一个非常好的理解过程,由于有很多打包流程,这里贴出来一个比较详细的供大家参考
    点这里,这个过程比较详细

    2.导入下图中的几个文件


    Paste_Image.png

    3.项目内初始化关键代码,写入即可运行

        // 创建盛放视频播放器的父视图 用于改变全屏和缩小
        _headPlayerView = [[UIView alloc]initWithFrame:CGRectMake(0, 0,  [UIScreen mainScreen].bounds.size.width,  [UIScreen mainScreen].bounds.size.width*videoTempProgress)];
        [self.view addSubview:_headPlayerView];
    
       //测试地址
       //rtmp 直播 香港电视台测试地址 rtmp://live.hkstv.hk.lxdns.com/live/hks
       //录播 播放流http://hc.yinyuetai.com/uploads/videos/common/E49E014999C93F5A88EA01B2B48161CE.flv?sc=fc5276d37b6cd89c&br=775&vid=2178416&aid=2650&area=Other&vst=3
        
      //该模型可以随意设置  来传入你想自定义的内容
      XYVideoModel *model = [[XYVideoModel alloc]init];
        model.url = [NSURL URLWithString:@"http://hc.yinyuetai.com/uploads/videos/common/E49E014999C93F5A88EA01B2B48161CE.flv?sc=fc5276d37b6cd89c&br=775&vid=2178416&aid=2650&area=Other&vst=3"];
        model.name = @"测试标题测试标题测试标题";
        model.coverimg = @"coverimg.jpeg";
        
        // 创建视频播放控件
        self.playerView = [[LMVideoPlayerView alloc]initWithModel:model];
        //遵循LMVideoPlayerViewDelegate 来实现退出全屏 和 放大的代理
        self.playerView.delegate = self;
        [_headPlayerView addSubview:self.playerView];
    
    #pragma mark XYVideoPlayerViewDelegate
    //全屏按钮代理方法
    - (void)fullScreenWithPlayerView:(LMVideoPlayerView *)videoPlayerView
    {
    //点击放大旋转和返回缩小的方法
        if (self.playerView.isRotate) {
            [UIView animateWithDuration:0.3 animations:^{
                _headPlayerView.transform = CGAffineTransformRotate(_headPlayerView.transform, M_PI_2);
                _headPlayerView.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height);
                self.playerView.frame = _headPlayerView.bounds;
                
            }];
            
        }else{
            
            [UIView animateWithDuration:0.3 animations:^{
                _headPlayerView.transform = CGAffineTransformIdentity;
                _headPlayerView.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.width*videoTempProgress);
                self.playerView.frame = _headPlayerView.bounds;
            }];
            
        }
    }
    //返回按钮代理方法
    - (void)backToBeforeVC{
        
        if (!self.playerView.isRotate) {
            
            [self.navigationController popViewControllerAnimated:YES];
        }
    }
    
    

    ** github demo地址**

    demo地址,欢迎star

    如果有任何疑问和对ijk的理解问题,可以随时留言或者私信沟通

    相关文章

      网友评论

      本文标题:iOS 视频直播与录播拉流框架1.0

      本文链接:https://www.haomeiwen.com/subject/mggwgttx.html