Как программно получить статус блютуса (ВКЛ / ВЫКЛ) в iphone

Я пытаюсь получить статус iPhone/iPod Bluetooth, который включен или выключен программно. Возможно ли использовать какой-нибудь Apple API или сторонний API.

6 ответов

Небольшое исследование ответа Сэма, которым я поделился с вами. Вы можете сделать это без использования частного API, но с несколькими оговорками:

  • Это будет работать только на iOS 5.0+
  • Он будет работать только на устройствах, которые поддерживают спецификацию bluetooth LE (iPhone 4S+, iPod 5-го поколения +, iPad 3-го поколения +)
  • Простое выделение класса заставит ваше приложение запрашивать разрешение на использование стека bluetooth у пользователя (может быть нежелательно), и если они откажутся, единственное, что вы увидите, это CBCentralManagerStateUnauthorized.
  • Восстановление состояния Bluetooth является асинхронным и непрерывным. Вам нужно будет настроить делегата для получения изменений состояния, так как проверка состояния недавно выделенного менеджера Bluetooth вернет CBCentralManagerStateUnknown

Тем не менее, этот метод, по-видимому, обеспечивает в режиме реального времени обновления состояния стека Bluetooth.

После включения платформы CoreBluetooth,

#import <CoreBluetooth/CoreBluetooth.h>

Эти тесты было легко выполнить с помощью:

- (void)detectBluetooth
{
    if(!self.bluetoothManager)
    {
        // Put on main queue so we can call UIAlertView from delegate callbacks.
        self.bluetoothManager = [[CBCentralManager alloc] initWithDelegate:self queue:dispatch_get_main_queue()];
    }
    [self centralManagerDidUpdateState:self.bluetoothManager]; // Show initial state
}

- (void)centralManagerDidUpdateState:(CBCentralManager *)central
{
    NSString *stateString = nil;
    switch(self.bluetoothManager.state)
    {
        case CBCentralManagerStateResetting: stateString = @"The connection with the system service was momentarily lost, update imminent."; break;
        case CBCentralManagerStateUnsupported: stateString = @"The platform doesn't support Bluetooth Low Energy."; break;
        case CBCentralManagerStateUnauthorized: stateString = @"The app is not authorized to use Bluetooth Low Energy."; break;
        case CBCentralManagerStatePoweredOff: stateString = @"Bluetooth is currently powered off."; break;
        case CBCentralManagerStatePoweredOn: stateString = @"Bluetooth is currently powered on and available to use."; break;
        default: stateString = @"State unknown, update imminent."; break;
    }
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Bluetooth state"
                                                     message:stateString
                                                    delegate:nil
                                          cancelButtonTitle:@"ok" otherButtonTitles: nil];
    [alert show];
}

Чтобы отключить предупреждающее сообщение по умолчанию, вам просто нужно пройти через словарь опций при создании экземпляра CBPeripheralManager:

SWIFT протестирован на iOS8+

import CoreBluetooth

//Define class variable in your VC/AppDelegate
var bluetoothPeripheralManager: CBPeripheralManager?

 //On viewDidLoad/didFinishLaunchingWithOptions
let options = [CBCentralManagerOptionShowPowerAlertKey:0] //<-this is the magic bit!
bluetoothPeripheralManager = CBPeripheralManager(delegate: self, queue: nil, options: options)

Очевидно, что вам также необходимо реализовать метод делегата CKManagerDelegate Периферический ManagerDidUpdateState, как описано выше:

func peripheralManagerDidUpdateState(peripheral: CBPeripheralManager!) {

    var statusMessage = ""

    switch peripheral.state {
    case .poweredOn:
        statusMessage = "Bluetooth Status: Turned On"

    case .poweredOff:
        statusMessage = "Bluetooth Status: Turned Off"

    case .resetting:
        statusMessage = "Bluetooth Status: Resetting"

    case .unauthorized:
        statusMessage = "Bluetooth Status: Not Authorized"

    case .unsupported:
        statusMessage = "Bluetooth Status: Not Supported"

    case .unknown:
        statusMessage = "Bluetooth Status: Unknown"
    }

    print(statusMessage)

    if peripheral.state == .poweredOff {
        //TODO: Update this property in an App Manager class
    }
}

Этот ответ был обновлен с оригинальной Objective-C до Swift 4.0.

Предполагается, что вы уже создали менеджер Bluetooth и назначили делегата ViewController учебный класс.

import CoreBluetooth

extension ViewController : CBCentralManagerDelegate {
    func centralManagerDidUpdateState(_ central: CBCentralManager) {
        switch central.state {
        case .poweredOn:
            print("powered on")
        case .poweredOff:
            print("powered off")
        case .resetting:
            print("resetting")
        case .unauthorized:
            print("unauthorized")
        case .unsupported:
            print("unsupported")
        case .unknown:
            print("unknown")
        }
    }
}

В некоторых обновлениях ответа BadPirate в iOS7 вы можете настроить центральный менеджер не показывать предупреждение при выделении объекта менеджера, назначив ему NSDictionary с ключом "CBCentralManagerOptionShowPowerAlertKey", установленным в 0.

self.cbManager = [[CBCentralManager alloc] initWithDelegate:self
                                                          queue:nil
                                                        options:
                      [NSDictionary dictionaryWithObject:[NSNumber numberWithInt:0]
                                                  forKey:CBCentralManagerOptionShowPowerAlertKey]];

Существует способ на iOS 5 и выше с использованием CoreBluetooth. Класс, который вы можете использовать, - CBCentralManager. У него есть свойство 'state', которое вы можете проверить, чтобы увидеть, включен Bluetooth или нет. (перечисление CBCentralManagerState имеет значения, с которыми вы хотите проверить).

Как только у вас будет CBCentralManager настройка, которую вы можете использовать CBCentralManager::state а также CBCentralManager::authorizationлибо из метода делегата, либо напрямую.

import CoreBluetooth

class Manager {
    let centralManager = CBCentralManager(delegate: self, queue: nil)

    var isBTTurnedOn: Bool {
        return centralManager.state == .poweredOn
    }

    var isAuthorized: Bool {
        if #available(iOS 13.0, *) {
            return centralManager.authorization == .allowedAlways
        } else {
            return true
        }
    }
}

Это решение немного устарело, до того как Apple представила ядро ​​Bluetooth

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        // Override point for customization after application launch.


        Class BluetoothManager = objc_getClass( "BluetoothManager" ) ;
        id btCont = [BluetoothManager sharedInstance] ;
        [self performSelector:@selector(status:) withObject:btCont afterDelay:1.0f] ;

        return YES ;
    }


    - (void)status:(id)btCont
    {
        BOOL currentState = [btCont enabled] ;
        //check the value of currentState 

    }
Другие вопросы по тегам