44 lines
1.6 KiB
Markdown
44 lines
1.6 KiB
Markdown
# bluetooth_low_energy
|
|
|
|
A bluetooth low energy plugin for flutter, which can be used to develope central role apps.
|
|
|
|
## Features
|
|
|
|
### Central APIs
|
|
- [x] Scan advertisements.
|
|
- [x] Connect/Disconnect to peripherals.
|
|
- [x] Read/Write/Notify characteristics.
|
|
- [x] Read/Write descriptors.
|
|
|
|
### Peripheral APIs
|
|
- [ ] Add/Send advertisements.
|
|
- [ ] Add services
|
|
- [ ] Add/Listen/Write characteristics
|
|
- [ ] Add/Listen/Write descriptors.
|
|
- [ ] Listen GATT connect/disconnect events.
|
|
|
|
## Getting Started
|
|
|
|
Add `bluetooth_low_energy` as a [dependency in your pubspec.yaml file](https://flutter.dev/using-packages/).
|
|
|
|
```
|
|
dependencies:
|
|
bluetooth_low_energy: ^<latest-version>
|
|
```
|
|
|
|
*Note*: Bluetooth Low Energy doesn't work on Android emulators, so use physical devices which has bluetooth features for development.
|
|
|
|
### Android
|
|
|
|
Make sure you have a `miniSdkVersion` with 21 or higher in your `android/app/build.gradle` file.
|
|
|
|
### iOS
|
|
|
|
Make sure you have a minimum deployment target of 9.0 or above, you can uncomment the first line `platform :ios, '9.0'` in your iOS project's `Podfile`.
|
|
|
|
*Note*: According to Apple's [documents](https://developer.apple.com/documentation/corebluetooth/), you must include the [`NSBluetoothAlwaysUsageDescription`](https://developer.apple.com/documentation/bundleresources/information_property_list/nsbluetoothalwaysusagedescription) on or after iOS 13, and include the [`NSBluetoothPeripheralUsageDescription`](https://developer.apple.com/documentation/bundleresources/information_property_list/nsbluetoothperipheralusagedescription) key before iOS 13.
|
|
|
|
## Issues
|
|
|
|
- Peripheral APIs are not implemented yet.
|