iOS开发---直播功能、速成

最近开发一个直播项目,百度云推流SDK(推流) + 百度云流媒体 + ijkplayer(拉流) 简单的实现了直播功能。在这里说一下用法过程。

首先注册百度云账号按照推流SDK配置Xcode环境,百度云推流SDK开发文档 ,下面说一下用法:

1.配置一下plist文件


2.导入百度云推流SDKdemo里面的文件


3.在需要直播的点击事件里写上一下代码

 NSString* name;
    if (self.model.direction == DirectionPortrait) {
        name = @"StreamingPortrait";
    } else {
        name = @"StreamingLandscape";
    }
    
    dispatch_async(dispatch_get_main_queue(), ^{
        UIStoryboard* board = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
        StreamingViewController* vc = (StreamingViewController*)[board instantiateViewControllerWithIdentifier:name];
        StreamingViewModel* vm = [[StreamingViewModel alloc] initWithSettingViewModel:self.model];
        vc.model = vm;
        [self.navigationController pushViewController:vc animated:YES];
    });
4.初始化推流参数等

- (void)viewDidLoad {
    [super viewDidLoad];
 [self initialLivePlay];//初始化推流参数
}
#pragma mrak -- 直播推流
-(void)initialLivePlay{//初始化推流参数
    self.model = [[SettingViewModel alloc] init];
    self.navigationController.delegate = self;
    self.model.url = @"rtmp://push.bcelive.com/live/zbgxhodqmyinbfodpv";//推流地址
    self.model.resolution = (Resolution)720;//1080p,720p
    self.model.direction = (Direction)0;//横竖屏
    
    NSLog(@"横竖屏%ld",(long)self.model.direction);
    
}

- (void)navigationController:(UINavigationController *)navigationController
      willShowViewController:(UIViewController *)viewController
                    animated:(BOOL)animated {

    if (self.model.direction == DirectionPortrait) {
        return;
    }

    if (viewController != self) {
        [self rotateVC:M_PI_2];
        
    } else {
        [self rotateVC:-M_PI_2];
        
    }
}

- (void)rotateVC:(CGFloat)angle {
    CGSize screenSize = [UIScreen mainScreen].bounds.size;
    CGPoint center = CGPointMake(screenSize.width / 2, screenSize.height / 2);
    self.navigationController.view.center = center;
    CGAffineTransform transform = CGAffineTransformMakeRotation(angle);
    if (angle < 0) {
        transform = CGAffineTransformIdentity;
    }
    self.navigationController.view.transform = transform;

    CGRect bounds = CGRectMake(0, 0, screenSize.height , screenSize.width);
    if (angle < 0) {
        bounds = CGRectMake(0, 0, screenSize.width , screenSize.height);
    }

    self.navigationController.view.bounds = bounds;
}
以上,推流就完成了。

拉流呢,我看了看百度的拉流,有点麻烦,还不如bilibili的ijkplayer关于IJKMediaFramework的集成 , 链接里有介绍ijk的集成方法,也可以去下载IJKMediaFramework和播放代码


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wuwuFQ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值