如何快速的开发一个完整的iOS直播app(创建房间)
直播(创建房间)
- 1.进入主播界面,首先创建房间
- 2.设计房间模型(key,名称),key作为房间的唯一标识,用来找到房间
- 3.用socket创建房间,导入socket.io框架
- 4.一般一个客户端一个socket就好了,可以搞个全局的socket
- 5.客户端代码(需要封装) 1.一个获取全局的socket 2.一个连接方法封装
- 6.可以在程序一启动的时候,就建立socket连接
- 7.每次点击创建房间,直接发送请求就好了
- 8.监听创建房间是否成功,因为有时候会重名
创建房间客户端代码
AppDelegate.m
[[SocketIOClient clientSocket] connectWithSuccess:^{
NSLog(@"建议连接成功");
// 创建房间
[[SocketIOClient clientSocket] emit:@"createRoom" with:@[item.mj_keyValues]];
}];
XMGBroadcasterViewController.m
- (IBAction)createRoom:(id)sender {
// 获取房间名称
if (_textField.text.length == 0) {
[SVProgressHUD showImage:nil status:@"请输出房间名称"];
[SVProgressHUD setDefaultStyle:SVProgressHUDStyleLight];
return;
}
// 创建房间
NSString *roomName = _textField.text;
XMGRoomItem *item = [XMGRoomItem itemWithName:roomName];
// 创建房间
[[SocketIOClient clientSocket] emit:@"createRoom" with:@[item.mj_keyValues]];
}
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
UIImageView *imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"blur"]];
imageView.frame = self.view.bounds;
[_preView addSubview:imageView];
// 监听创建房间是否成功
[[SocketIOClient clientSocket] on:@"createRoomResult" callback:^(NSArray * _Nonnull data, SocketAckEmitter * _Nonnull ack) {
BOOL success = [data[0] boolValue];
if (success) {
// 进入主播界面,移除高斯模糊
[_blurView removeFromSuperview];
} else {
// 清空文本框
_textField.text = @"";
// 提示重新输入
[SVProgressHUD showImage:nil status:@"房间同名,请重新输入房间名称"];
}
}];
}
创建房间服务端代码
- 1.每开启一个房间,服务端开启一个socket分组,应该搭建WebSocket服务器
- 2.服务器代码
- 3.连接成功后,监听创建房间
- 1.判断房间名是否重复,使用underScore框架,操作数组,需要用npm下载
- 2.没有重名,就执行下面操作3,4,5
- 发送创建房间成功事件,通知客户端
- 3.保存房间
- 4.添加socket分组
- 5.记录当前socket正在直播的房间,一个主播只会开启一个房间,当主播关闭的时候,需要把当前房间移除.
// 监听创建房间
clientSocket.on('createRoom',function(data){
// 判断房间名是否一样
var roomNameArr = Object.keys(rooms).map(function(roomKey){
return rooms[roomKey];
})
// 获取结果
var createRoomResult = underscore.contains(roomNameArr,data.roomName);
// 发送结果给客户端
serverSocket.emit('createRoomResult',!createRoomResult);
if(createRoomResult == false){
console.log('创建新的房间');
// 之前没有包含房间,可以创建新的房间
clientSocket.roomKey = rooms[data.roomKey];
// 保存房间
rooms[data.roomKey] = data.roomName;
// 分组
- 9.监听失去连接,需要把当前主播房间移除,分组也移除,因为表示当前主播不播了
// 失去连接
// 失去连接
clientSocket.on('disconnect',function(){
// 清空当前房间
if(clientSocket.roomKey) {
delete rooms[roomKey];
clientSocket.leave(roomKey);
}
});
如何快速的开发一个完整的iOS直播app(创建房间)的更多相关文章
- 【如何快速的开发一个完整的iOS直播app】(美颜篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,美颜功能是很重 ...
- 【如何快速的开发一个完整的iOS直播app】(采集篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,首先需要采集主 ...
- 【如何快速的开发一个完整的iOS直播app】(播放篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看上篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,集成ijkpl ...
- 【如何快速的开发一个完整的iOS直播app】(原理篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 目录 [如何快速的开发一个完整的iOS直播app](原理篇) [如何快速的开发一个完整的iOS直播app](播放篇) [如何快速的开发一个完整的 ...
- 【如何快速的开发一个完整的iOS直播app】(推流篇)
前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,肯定需要流媒体服务器,本篇主要讲解直播中流媒体服务器搭建,并且讲解了如 ...
- 【如何快速的开发一个完整的 iOS 直播 app】(美颜篇)
来源:袁峥Seemygo 链接:http://www.jianshu.com/p/4646894245ba 前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播 ...
- 如何快速的开发一个完整的iOS直播app(原理篇)
目录 [如何快速的开发一个完整的iOS直播app](原理篇) [如何快速的开发一个完整的iOS直播app](播放篇) [如何快速的开发一个完整的iOS直播app](采集篇) 前言 大半年没写博客了,但 ...
- 如何快速的开发一个完整的iOS直播app(美颜篇)
前言 在看这篇之前,如果您还不了解直播原理,请查看这篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,美颜功能是很重要的,如果没有美颜功能,可能分分钟钟掉粉千万,本篇主要讲 ...
- 【如何快速的开发一个简单的iOS直播app】(代码篇)
开篇([如何快速的开发一个完整的iOS直播app](原理篇)) 好久没写简书,因为好奇的我跑去学习直播了,今天就分享一下我的感慨. 目前为止直播还是比较热点的技术的,简书,git上有几篇阅读量和含金量 ...
- 抖音短视频爆火的背后到底是什么——如何快速的开发一个完整的直播app
前言 今年移动直播行业的兴起,诞生了一大批网红,甚至明星也开始直播了,因此不得不跟上时代的步伐,由于第一次接触的原因,因此花了很多时间了解直播,今天我来教你从零开始搭建一个完整的直播app,希望能帮助 ...
随机推荐
- Flink 中的事件时间触发器和处理时间触发器
EventTimeTrigger EventTimeTrigger 的触发完全依赖 watermark,换言之,如果 stream 中没有 watermark,就不会触发 EventTimeTrigg ...
- swoole的安装
因为换了一台工作电脑 需要重新安装各种环境,这里简单记录一下swoole的安装步骤. 首先去下载它的git仓库: $ git clone https://gitee.com/swoole/swoole ...
- 全网最适合入门的面向对象编程教程:59 Python并行与并发-并行与并发和线程与进程
全网最适合入门的面向对象编程教程:59 Python 并行与并发-并行与并发和线程与进程 摘要: 在 Python 中,"并行"(parallelism)与"并发&quo ...
- tsconfig配置详解
{ "compilerOptions": { /* Basic Options */ "target": "es5" /* target用于 ...
- mouseup模拟drag与click事件冲突
今天要说一个很隐晦的东西,一般可能很难碰到,碰到了可能很难解决.就是当我们自己用mousestart,mousemove,mouseup做自定义拖拽效果的时候,如果这个时候配上click就会引发一个拖 ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online (The 2nd Universal Cup
The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online (The 2nd Universal Cup. Stage 1: Qingdao) J ...
- 鸿蒙NEXT元服务:论如何免费快速上架作品
[引言]天下武功,唯快不破. 本文讨论如何免费且以最快速度上架自己的作品. 作者以自己从零开始到提交发布审核一共俩小时的操作流程分享给大家作参考. [1]立项选择 结论:元服务,单机,工具类(非游戏) ...
- AtCoder Beginner Contest 379
Contest Link C 妙妙贪心题,居然需要高斯求和公式. Submission D 妙妙套路题,维护全局 lazytag,easy to solve. Submission E 妙妙拆贡献题, ...
- IDEA 一个服务同时启动多个实例
有些时候为了测试,服务的分发,我们可以在IDEA中对一个微服务启动多个实例,配置方法如下: 1.编辑同时启动的微服务. 勾选 allow parallel run 2.编辑完成后复制一份配置. 3.复 ...
- Net5学习笔记
IOC 容器IServiceCollection 什么是Ioc 把对象的统一创建交给第三方容器来创建 如何使用内置IOC ServerCollection 1.在Starup中的ConfigurSer ...