Я сканирую свое периферийное устройство следующим образом:
NSDictionary *scanOptions = [NSDictionary dictionaryWithObject:[NSNumber numberWithBool:NO]
forKey:CBCentralManagerScanOptionAllowDuplicatesKey];
// Scan for peripherals with given UUID
[cm scanForPeripheralsWithServices:[NSArray arrayWithObject:HeliController.serviceUUID] options:scanOptions]
Нет проблем, я нахожу периферийное устройство и могу к нему подключиться. Как видите, я даю CBCentralManagerScanOptionAllowDuplicatesKey
с bool NO
, чтобы не допускать более одного периферийного устройства, но иногда didDiscoverPeripheral
callback срабатывает дважды.
- (void) centralManager:(CBCentralManager *)central
didDiscoverPeripheral:(CBPeripheral *)peripheral
advertisementData:(NSDictionary *)advertisementData
RSSI:(NSNumber *)RSSI
{
if(!discovered){
discovered = YES;
NSLog(@"Discovered");
[cm stopScan];
[scanButton setTitle:@"Connect" forState:UIControlStateNormal];
}
else if(discovered){
discovered = YES
NSLog(@"Already discovered");
}
}
Несколько раз я получаю
Discovered
Already discovered
как вывод в моей консоли, и в большинстве случаев отображается только Discovered
message.
В моем периферийном делегате я сначала обнаруживаю службы, которые затем вызывают [peripheral discoverCharacteristics
, и всегда происходит обратный вызов:
- (void) peripheral:(CBPeripheral *)peripheral didDiscoverCharacteristicsForService:(CBService *)service error:(NSError *)error{
NSLog(@"Did discover characteristic for service %@", [service.peripheral UUID]);
for(CBCharacteristic *c in [service characteristics]){
// We never get here when peripheral is discovered twice
if([[c UUID] isEqual:myCharacteristicUUID]){
NSLog(@"Found characteristic");
self.throttleCharacteristic = c;
}
}
Когда didDiscoverPeripheral
встречается дважды, service
становится nil
в этом методе, даже если peripheral
нет (UUID, имя по-прежнему правильное).
Перезагрузка телефона или сброс настроек сети временно устраняет проблему.
Мне очень нужно это исправить! Спасибо