O Bluetooth de baixa energia (BLE) economiza energia ao permanecer no modo de espera na maioria das vezes. Ele acorda apenas para fazer anúncios e de modo que os anúncios afetam o consumo de energia largura de banda de transferência de dados.
Extensão de publicidade Bluetooth 5
O Android 8.0 tem suporte ao Bluetooth 5, que oferece transmissão e divulgação de dados flexível para BLE. Bluetooth 5 com suporte a BLE físico Camadas (PHYs) que retêm redução no consumo de energia do Bluetooth 4.2 e permitir que os usuários escolham largura de banda ou intervalo maior. Para mais informações, acesse a Especificações do Bluetooth 5 Core.
Implementação
Novos recursos do Bluetooth 5 disponíveis automaticamente para dispositivos
executando o Android 8.0 com controladores Bluetooth compatíveis. Use estas
BluetoothAdapter
métodos para verificar se um dispositivo é compatível com recursos do Bluetooth 5:
isLe2MPhySupported()
isLeCodedPhySupported()
isLeExtendedAdvertisingSupported()
isLePeriodicAdvertisingSupported()
Para desativar os Recursos de publicidade, use o chip Bluetooth fornecedor para desativar o suporte a chipset.
Os PHYs do Bluetooth são exclusivos, e o comportamento
cada PHY é predefinido pela SIG do Bluetooth. Por padrão, o Android 8.0
usa o Bluetooth LE 1M PHY do Bluetooth 4.2. A
android.bluetooth.le
expõe os recursos de publicidade do Bluetooth 5 usando estes
APIs:
AdvertisingSet
AdvertisingSetCallback
AdvertisingSetParameters
PeriodicAdvertisingParameters
Criar um
AdvertisingSet
para modificar as configurações de publicidade Bluetooth usando startAdvertisingSet()
.
em
android.bluetooth.le.BluetoothLeAdvertiser
. Mesmo que
suporte para Bluetooth 5 ou os Recursos de publicidade dele for desativado, o
Os recursos da API também podem se aplicar ao LE 1M PHY.
Exemplos
Este app de exemplo usa o Bluetooth LE 1M PHY para publicidade:
// Start legacy advertising. Works for devices with 5.x controllers, // and devices that support multi-advertising. void example1() { BluetoothLeAdvertiser advertiser = BluetoothAdapter.getDefaultAdapter().getBluetoothLeAdvertiser(); AdvertisingSetParameters parameters = (new AdvertisingSetParameters.Builder()) .setLegacyMode(true) // True by default, but set here as a reminder. .setConnectable(true) .setInterval(AdvertisingSetParameters.INTERVAL_HIGH) .setTxPowerLevel(AdvertisingSetParameters.TX_POWER_MEDIUM) .build(); AdvertiseData data = (new AdvertiseData.Builder()).setIncludeDeviceName(true).build(); AdvertisingSetCallback callback = new AdvertisingSetCallback() { @Override public void onAdvertisingSetStarted(AdvertisingSet advertisingSet, int txPower, int status) { Log.i(LOG_TAG, "onAdvertisingSetStarted(): txPower:" + txPower + " , status: " + status); currentAdvertisingSet = advertisingSet; } @Override public void onAdvertisingDataSet(AdvertisingSet advertisingSet, int status) { Log.i(LOG_TAG, "onAdvertisingDataSet() :status:" + status); } @Override public void onScanResponseDataSet(AdvertisingSet advertisingSet, int status) { Log.i(LOG_TAG, "onScanResponseDataSet(): status:" + status); } @Override public void onAdvertisingSetStopped(AdvertisingSet advertisingSet) { Log.i(LOG_TAG, "onAdvertisingSetStopped():"); } }; advertiser.startAdvertisingSet(parameters, data, null, null, null, callback); // After onAdvertisingSetStarted callback is called, you can modify the // advertising data and scan response data: currentAdvertisingSet.setAdvertisingData(new AdvertiseData.Builder(). setIncludeDeviceName(true).setIncludeTxPowerLevel(true).build()); // Wait for onAdvertisingDataSet callback... currentAdvertisingSet.setScanResponseData(new AdvertiseData.Builder().addServiceUuid(new ParcelUuid(UUID.randomUUID())).build()); // Wait for onScanResponseDataSet callback... // When done with the advertising: advertiser.stopAdvertisingSet(callback); }
Este app de exemplo usa o BLE 2M PHY para publicidade. O app em primeiro lugar
verifica se o dispositivo é compatível com os recursos que estão sendo usados. Se o
se os recursos de publicidade forem compatíveis, o app vai configurar o BLE 2M
PHY como o PHY principal. Enquanto 2 milhões de PHY estão ativos, o anúncio não
não oferece suporte a controles com Bluetooth 4.x, então setLegacyMode
é definido como false
. Este exemplo modifica os parâmetros enquanto
publicidade e também a pausa.
void example2() { BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter(); BluetoothLeAdvertiser advertiser = BluetoothAdapter.getDefaultAdapter().getBluetoothLeAdvertiser(); // Check if all features are supported if (!adapter.isLe2MPhySupported()) { Log.e(LOG_TAG, "2M PHY not supported!"); return; } if (!adapter.isLeExtendedAdvertisingSupported()) { Log.e(LOG_TAG, "LE Extended Advertising not supported!"); return; } int maxDataLength = adapter.getLeMaximumAdvertisingDataLength(); AdvertisingSetParameters.Builder parameters = (new AdvertisingSetParameters.Builder()) .setLegacyMode(false) .setInterval(AdvertisingSetParameters.INTERVAL_HIGH) .setTxPowerLevel(AdvertisingSetParameters.TX_POWER_MEDIUM) .setPrimaryPhy(BluetoothDevice.PHY_LE_1M) .setSecondaryPhy(BluetoothDevice.PHY_LE_2M); AdvertiseData data = (new AdvertiseData.Builder()).addServiceData(new ParcelUuid(UUID.randomUUID()), "You should be able to fit large amounts of data up to maxDataLength. This goes up to 1650 bytes. For legacy advertising this would not work".getBytes()).build(); AdvertisingSetCallback callback = new AdvertisingSetCallback() { @Override public void onAdvertisingSetStarted(AdvertisingSet advertisingSet, int txPower, int status) { Log.i(LOG_TAG, "onAdvertisingSetStarted(): txPower:" + txPower + " , status: " + status); currentAdvertisingSet = advertisingSet; } @Override public void onAdvertisingSetStopped(AdvertisingSet advertisingSet) { Log.i(LOG_TAG, "onAdvertisingSetStopped():"); } }; advertiser.startAdvertisingSet(parameters.build(), data, null, null, null, callback); // After the set starts, you can modify the data and parameters of currentAdvertisingSet. currentAdvertisingSet.setAdvertisingData((new AdvertiseData.Builder()).addServiceData(new ParcelUuid(UUID.randomUUID()), "Without disabling the advertiser first, you can set the data, if new data is less than 251 bytes long.".getBytes()).build()); // Wait for onAdvertisingDataSet callback... // Can also stop and restart the advertising currentAdvertisingSet.enableAdvertising(false, 0, 0); // Wait for onAdvertisingEnabled callback... currentAdvertisingSet.enableAdvertising(true, 0, 0); // Wait for onAdvertisingEnabled callback... // Or modify the parameters - i.e. lower the tx power currentAdvertisingSet.enableAdvertising(false, 0, 0); // Wait for onAdvertisingEnabled callback... currentAdvertisingSet.setAdvertisingParameters(parameters.setTxPowerLevel (AdvertisingSetParameters.TX_POWER_LOW).build()); // Wait for onAdvertisingParametersUpdated callback... currentAdvertisingSet.enableAdvertising(true, 0, 0); // Wait for onAdvertisingEnabled callback... // When done with the advertising: advertiser.stopAdvertisingSet(callback); }
Verificação
Execute aplicáveis Testes de produtos Bluetooth para verificar a compatibilidade do dispositivo com Bluetooth 5.