Как программно получить статус блютуса (ВКЛ / ВЫКЛ) в 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
}