如何开发出一款仿映客直播APP项目实践篇 -【播放篇】

日期:2016-11-25 16:30:00

【目录】

本篇主要讲解的是直播app中,需要用到的一个很重要的开源框架ijkplayer)的使用,开发一款直播app,集成ijkplayer成功后,就算完成直播功能一半的工程了,只要有拉流url,就能播放直播啦

1.推荐自己把IJKMediaPlayer打包成静态库,在导入到自己的项目中。

集成对于初学者很麻烦 想自己集成的请看这个博客:iOS中集成ijkplayer视频直播框架
我自己打包了ijkplayer一个库,用于调试和发布(DEBUG和Release),点击下载;
(另外有分开的两个版本库,分别用于调试和发布(DEBUG和Release),点击下载

2.直接把下载好的ijkplayer静态库拖入到自己的工程中,

调试的话,拖入ijkplayer静态库


Snip20161124_12.png
3.导入ijkplayer依赖的库,具体可以查看ijkplayer的README

Snip20160829_6.png

添加库


Snip20161124_13.png

【使用ijkplayer直播】

1.ijkplayer用法简介
ijkplayer用法比较简单,其实只要有直播地址,就能直播了
注意:最好真机测试,模拟器测试比较卡,不流畅,真机就没有问题了

2.抓取数据
映客直播地址:
#define URL @"http://116.211.167.106/api/live/aggregation?uid=133825214&interest=1"
在ViewListViewController.h中加载tableView数据

-(void)loadData{ self.manager = [AFHTTPSessionManager manager]; self.manager.responseSerializer = [AFHTTPResponseSerializer serializer]; self.manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"text/plain", nil];
    [self.manager POST:URL parameters:nil progress:^(NSProgress * _Nonnull uploadProgress) {
    } success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { id obj =[NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil]; NSLog(@"viewListData:%@",obj);
        _dataArry = [YZLiveItem mj_objectArrayWithKeyValuesArray:obj[@"lives"]];

        [_tableView reloadData];
    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { NSLog(@"error:%@",error);
    }];

}

3.获取拉流url,直播界面LiveViewController.h

// 拉流地址 NSURL *url = [NSURL URLWithString:_item.stream_addr];

    _ijkLiveVeiw = [[IJKFFMoviePlayerController alloc]initWithContentURL:url withOptions:nil];
    _ijkLiveVeiw.view.frame = SCREEN;
    [_ijkLiveVeiw prepareToPlay];

    [self.view addSubview:_ijkLiveVeiw.view];

4.结束播放
LiveViewController.h界面消失不播放,一定要记得结束播放,否则会报内存溢出

-(void)viewDidDisappear:(BOOL)animated{
    [super viewDidDisappear:YES]; if (_ijkLiveVeiw) {
        [_ijkLiveVeiw pause];
        [_ijkLiveVeiw stop];
        [_ijkLiveVeiw shutdown];
    }
}

效果图:


IMG_4338.PNG

IMG_4339.PNG

代码地址:
gitHub : https://github.com/one-tea/ZKKLiveDemo

让我们协助您将需求落地

*请填写需求信息,我们会在24小时内与您取得联系。