MultipeerConnectivity拓展
从上一篇博客我们对MultipeerConnectivity的开发,以及蓝牙4.0都有了一定的基础认识。蓝牙4.0因为传输速度的原因,所以做了一点便搁置了,主要尝试的是MultipeerConnectivity的开发,对MultipeerConnectivity简单做下总结。
MultipeerConnectivity信息交互流程
- a设备发送广播,并在广播中标记了特定的服务。
- b设备搜索附近中有相同特定服务的广播,然后发送连接请求。
- a设备收到b发送过来的请求,同意之后,会把b的一些基本信息保存在a中的会话session中
- b也会保存一些a的必要信息在b的会话session中,也就是说a和b都有自己连接的蓝牙的session信息,两个session是独立存在的
- a或b发送信息时选择自己session中连接的蓝牙peerID,进行发送,另外一端在时刻监听着会话代理
- (void)session:(MCSession *)session didReceiveData:(NSData *)data fromPeer:(MCPeerID *)peerID
中是否有接收数据。
自定义MultipeerConnectivity的Demo概要
利用系统自带的广播搜索连接,无法自定义搜索到的UI界面,而且对于连接请求需要手动点击确认。苹果sdk有提供自定义方法,sdk内容不多,可以自行查看。MultipeerConnectivitySDK
如截图所示,现在我们就来做一个自动搜索附近蓝牙设备,并自动连接的demo,可实现消息发送给指定的人。从sdk可知,若想实现自动连接附近蓝牙或断开需要用到MCNearbyServiceAdvertiser
和MCNearbyServiceBrowser
,关键内容如下:
- a设备既要发送广播又要搜索广播,即同时做以上a和b设备都要做的事,也就是说a类里同时有发送广播让别人搜索到进行连接的session,也有搜索别人的广播进行连接的session。两个session互不干扰。
- 多个设备进行连接,将消息通过中间连接的蓝牙中转设备发送给指定的人。
- 根据接收到的不同消息类型进行不同的处理。demo效果如下
MultipeerConnectivity代码详解
代码详解,因为这个博客工具还不太会用,所以暂且先用截图来展示代码,源代码下载见最底部
初始化,你需要两个会话session,一个用来保存自己连接的别人的广播,一个用来保存别人连接了你的广播。
点击“开始”开启广播并同时搜索附近的广播服务
当搜索到附近有对应的广播时会调用代理进行连接
连接开始或断开等,session的状态会发生改变,调用代理
- (void)session:(MCSession *)session peer:(MCPeerID *)peerID didChangeState:(MCSessionState)state
因为你在搜索附近广播的同时也在向附近发送着广播,所以一旦有附近的蓝牙进行连接请求的时候会调用广播代理- (void) advertiser:(MCNearbyServiceAdvertiser )advertiser didReceiveInvitationFromPeer:(MCPeerID )peerID
withContext:(nullable NSData *)context
这里注意一个app的bug,当使用
MCNearbyServiceAdvertiser
时,一定要调用代理- (void) session:(MCSession *)session
didReceiveCertificate:(nullable NSArray *)certificate
fromPeer:(MCPeerID *)peerID
certificateHandler:(void (^)(BOOL accept))certificateHandler,在block中返回yes。
连接完成,发送数据就是比较简单的了,用发送文字进行举例,demo只进行了发送给全部的我正在连接的session中的所有设备,需要调试者可自行修改
发送文字
接收数据,需要特别注意
因为消息的发送是异步,所以此方法没有在主线程中,为防止ui处理报错,所以切换为主线程!!!!!