Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: BLE_API mbed-dev-bin nRF51822
Fork of microbit-dal by
MicroBitBLEManager Class Reference
Class definition for the MicroBitBLEManager. More...
#include <MicroBitBLEManager.h>
Inherits MicroBitComponent.
| Public Member Functions | |
| MicroBitBLEManager (MicroBitStorage &_storage) | |
| Constructor. | |
| MicroBitBLEManager () | |
| Constructor. | |
| void | init (ManagedString deviceName, ManagedString serialNumber, EventModel &messageBus, bool enableBonding) | 
| Post constructor initialisation method as the BLE stack cannot be brought up in a static context. | |
| int | setTransmitPower (int power) | 
| Change the output power level of the transmitter to the given value. | |
| void | pairingMode (MicroBitDisplay &display, MicroBitButton &authorisationButton) | 
| Enter pairing mode. | |
| void | advertise () | 
| When called, the micro:bit will begin advertising for a predefined period, MICROBIT_BLE_ADVERTISING_TIMEOUT seconds to bonded devices. | |
| int | getBondCount () | 
| Determines the number of devices currently bonded with this micro:bit. | |
| void | pairingRequested (ManagedString passKey) | 
| A request to pair has been received from a BLE device. | |
| void | pairingComplete (bool success) | 
| A pairing request has been sucessfully completed. | |
| void | idleTick () | 
| Periodic callback in thread context. | |
| Private Member Functions | |
| virtual void | systemTick () | 
| The system timer will call this member function once the component has been added to the array of system components using system_timer_add_component. | |
| virtual int | isIdleCallbackNeeded () | 
| When added to the idleThreadComponents array, this function will be called to determine if and when data is ready. | |
Detailed Description
Class definition for the MicroBitBLEManager.
Definition at line 90 of file MicroBitBLEManager.h.
Constructor & Destructor Documentation
| MicroBitBLEManager | ( | MicroBitStorage & | _storage ) | 
Constructor.
Configure and manage the micro:bit's Bluetooth Low Energy (BLE) stack.
- Parameters:
- 
  _storage an instance of MicroBitStorage used to persist sys attribute information. (This is required for compatability with iOS). 
- Note:
- The BLE stack *cannot* be brought up in a static context (the software simply hangs or corrupts itself). Hence, the init() member function should be used to initialise the BLE stack.
Definition at line 201 of file MicroBitBLEManager.cpp.
Constructor.
Configure and manage the micro:bit's Bluetooth Low Energy (BLE) stack.
- Note:
- The BLE stack *cannot* be brought up in a static context (the software simply hangs or corrupts itself). Hence, the init() member function should be used to initialise the BLE stack.
Definition at line 217 of file MicroBitBLEManager.cpp.
Member Function Documentation
| void advertise | ( | ) | 
When called, the micro:bit will begin advertising for a predefined period, MICROBIT_BLE_ADVERTISING_TIMEOUT seconds to bonded devices.
Definition at line 229 of file MicroBitBLEManager.cpp.
| int getBondCount | ( | ) | 
Determines the number of devices currently bonded with this micro:bit.
- Returns:
- The number of active bonds.
Definition at line 384 of file MicroBitBLEManager.cpp.
| void idleTick | ( | ) |  [virtual] | 
Periodic callback in thread context.
We use this here purely to safely issue a disconnect operation after a pairing operation is complete.
Reimplemented from MicroBitComponent.
Definition at line 430 of file MicroBitBLEManager.cpp.
| void init | ( | ManagedString | deviceName, | 
| ManagedString | serialNumber, | ||
| EventModel & | messageBus, | ||
| bool | enableBonding | ||
| ) | 
Post constructor initialisation method as the BLE stack cannot be brought up in a static context.
- Parameters:
- 
  deviceName The name used when advertising serialNumber The serial number exposed by the device information service messageBus An instance of an EventModel, used during pairing. enableBonding If true, the security manager enabled bonding. 
 bleManager.init(uBit.getName(), uBit.getSerial(), uBit.messageBus, true);
Definition at line 248 of file MicroBitBLEManager.cpp.
| void pairingComplete | ( | bool | success ) | 
A pairing request has been sucessfully completed.
If we're in pairing mode, display a success or failure message.
- Note:
- for internal use only.
Definition at line 415 of file MicroBitBLEManager.cpp.
| void pairingMode | ( | MicroBitDisplay & | display, | 
| MicroBitButton & | authorisationButton | ||
| ) | 
Enter pairing mode.
This is mode is called to initiate pairing, and to enable FOTA programming of the micro:bit in cases where BLE is disabled during normal operation.
- Parameters:
- 
  display An instance of MicroBitDisplay used when displaying pairing information. authorizationButton The button to use to authorise a pairing request. 
 // initiate pairing mode
 bleManager.pairingMode(uBit.display, uBit.buttonA);
Definition at line 450 of file MicroBitBLEManager.cpp.
| void pairingRequested | ( | ManagedString | passKey ) | 
A request to pair has been received from a BLE device.
If we're in pairing mode, display the passkey to the user. Also, purge the bonding table if it has reached capacity.
- Note:
- for internal use only.
Definition at line 402 of file MicroBitBLEManager.cpp.
| int setTransmitPower | ( | int | power ) | 
Change the output power level of the transmitter to the given value.
- Parameters:
- 
  power a value in the range 0..7, where 0 is the lowest power and 7 is the highest. 
- Returns:
- MICROBIT_OK on success, or MICROBIT_INVALID_PARAMETER if the value is out of range.
 // maximum transmission power.
 bleManager.setTransmitPower(7);
Definition at line 369 of file MicroBitBLEManager.cpp.
Generated on Tue Jul 12 2022 19:47:36 by
 1.7.2
 1.7.2 
    