iOS_蓝牙的使用_获取周边外接设备

简单的获取周边的蓝牙设备需要以下几步

1、导入对应的框架

#import <CoreBluetooth/CoreBluetooth.h>

2、创建对象,遵循代理事件

创建CBCentralManager对象,并遵循CBCentralManagerDelegate代理协议

@interface BlueToothViewController ()<CBCentralManagerDelegate>
@property (nonatomic,strong) CBCentralManager *manager;
@end
//初始化并设置委托和线程队列
self.manager = [[CBCentralManager alloc]initWithDelegate:self queue:dispatch_get_main_queue()];

3、处理蓝牙状态
在CBCentralManagerDelegate代理方法中:

- (void)centralManagerDidUpdateState:(CBCentralManager *)central;
可以获取当前设备的蓝牙状态,**此代理方法必须实现**。同时可以在代理方法内利用UUIDService对周边设备进行过滤。
- (void)centralManagerDidUpdateState:(CBCentralManager *)central{
    switch(central.state){
        case CBManagerStateUnknown:
            NSLog(@">>>CBManagerStateUnknown");
            break;
        case CBManagerStateResetting:
            NSLog(@">>>CBManagerStateResetting");
            break;
        case CBManagerStateUnsupported:
            NSLog(@">>>CBManagerStateUnsupported");
            break;
        case CBManagerStateUnauthorized:
            NSLog(@">>>CBManagerStateUnauthorized");
            break;
        case CBManagerStatePoweredOff:
            NSLog(@">>>CBManagerStatePoweredOff");
            // 设备蓝牙未打开
            break;
        case CBManagerStatePoweredOn:
            NSLog(@">>>CBManagerStatePoweredOn");
            // 设备蓝牙打开
            // 第一个参数设为nil,即搜索周边所有的设备。
            //搜索所有的设备,不加限制
           // [central scanForPeripheralsWithServices:nil options:nil];
           // 搜索所有的小米手环设备,小米手环的UUIDService为FFE0
            [central scanForPeripheralsWithServices:@[[CBUUID UUIDWithString:@"FEE0"]] options:nil];
            // 第二个参数类型为字典,有多种状态值
            // [central scanForPeripheralsWithServices:@[[CBUUID UUIDWithString:@"FEE0"]]  options:@{CBCentralManagerScanOptionAllowDuplicatesKey : @YES }];
            break;
        default:
            break;
    }
}

4、获取周边蓝牙设备
在设备搜索到周边设备之后,会调用代理方法:

- (void)centralManager:(CBCentralManager *)central didDiscoverPeripheral:(CBPeripheral *)peripheral advertisementData:(NSDictionary *)advertisementData RSSI:(NSNumber *)RSSI;

在这个方法内的可以获取多个参数

- (void)centralManager:(CBCentralManager *)central didDiscoverPeripheral:(CBPeripheral *)peripheral advertisementData:(NSDictionary *)advertisementData RSSI:(NSNumber *)RSSI{
    //接下连接我们的测试设备,这里的测试设备是小米手环
   /*
   对象peripheral内包含多个外接设备的值:
       外接设备名称:peripheral.name
       外接设备识别码:peripheral.identifier
   字典advertisementData内包含以下几个字段:
       kCBAdvDataIsConnectable:外接设备是否可连接 1可以 0不可;
       这个值在搜索外接设备时肯定会存在,以下的几个字段在搜索到本人的电脑时就不存在,在搜索到的小米手环时就存在。
       kCBAdvDataLocalName:外接设备内置的名称
       kCBAdvDataManufacturerData:外接设备生产商数据
       kCBAdvDataServiceUUIDs:设备的UUIDService
   最后一个值RRSI:外接设备的信号强度,获取的值为负数,可以做以下处理,同时可以根据信号强度大致估计外接设备与设备之间的距离
   利用绝对值方法处理:abs([RSSI intValue])
   */
}

当搜索到需要的设备时需要主动去停止搜索,如果不主动去调用停止搜索设备的方法:
- (void)stopScan;
则会不停的搜索周边的设备。


测试中搜索到的小米手环处理之后的一些信息截图:
小米手环2
测试中搜索到的本机的设备信息截图:
搜索到电脑
测试中搜索到的未知其它设备
原本获取到的数据如果没有设备名称,将会是NULL,显示未知设备是经过处理的。
他人未知设备

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1024app_ios_2.3.4是一款专为iOS设备设计的应用程序,其版本号为2.3.4。该应用程序在功能上提供了丰富的内容和服务,可以满足用户在不同方面的需求。 1024app_ios_2.3.4首先具备了强大的应用市场功能,用户可以通过该应用程序方便地浏览和搜索各种类型的应用,包括游戏、社交媒体、工具类等。用户可以根据自己的兴趣和需求下载和安装这些应用,并在手机上进行使用。 其次,1024app_ios_2.3.4还提供了个性化推荐功能,根据用户的使用习惯和喜好,推荐适合用户的应用程序。这样,用户可以更加高效地发现和使用他们感兴趣的应用,提高了用户体验。 另,1024app_ios_2.3.4还支持应用的更新和升级。用户可以在应用程序中获得关于已安装应用的最新版本信息,并进行更新。这样,用户可以及时获得应用程序的最新功能和修复bug,提高了应用的稳定性和安全性。 最后,1024app_ios_2.3.4还具备了一些额的功能,例如用户可以在应用中进行应用评分和评论,与其他用户交流和分享使用心得。此,用户还可以通过该应用程序获取关于应用的详细信息,如应用的大小、开发者介绍等。 综上所述,1024app_ios_2.3.4是一款功能强大的iOS应用程序,用户可以在其中浏览和下载各种类型的应用,享受个性化推荐、应用更新和升级等服务。同时,用户还可以与其他用户互动交流,获取应用的详细信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值