android 蓝牙 le only,GitHub - litesuits/android-lite-bluetoothLE: BLE Framework. Based on Bluetooth 4....

LiteBle: Android Bluetooth Framework

Extremely simple! Based on callback.

Communication with BluetoothLE(BLE) device as easy as HTTP communication.

One Device, One connection, One LiteBluetooth Instance.

But One connection can has many callback:

One LiteBluetooth Instance can add many BluetoothGattCallback.

##Usage

###1. scan device

private static int TIME_OUT_SCAN = 10000;

liteBluetooth.startLeScan(new PeriodScanCallback(TIME_OUT_SCAN) {

@Override

public void onScanTimeout() {

dialogShow(TIME_OUT_SCAN + " Millis Scan Timeout! ");

}

@Override

public void onLeScan(BluetoothDevice device, int rssi, byte[] scanRecord) {

BleLog.i(TAG, "device: " + device.getName() + " mac: " + device.getAddress()

+ " rssi: " + rssi + " scanRecord: " + Arrays.toString(scanRecord));

}

});

###2. scan and connect

private static String MAC = "00:00:00:AA:AA:AA";

liteBluetooth.scanAndConnect(MAC, false, new BleGattCallback() {

@Override

public void onConnectSuccess(BluetoothGatt gatt, int status) {

// discover services !

gatt.discoverServices();

}

@Override

public void onServicesDiscovered(BluetoothGatt gatt, int status) {

BluetoothUtil.printServices(gatt);

dialogShow(MAC + " Services Discovered SUCCESS !");

}

@Override

public void onConnectFailure(BleException exception) {

bleExceptionHandler.handleException(exception);

dialogShow(MAC + " Services Discovered FAILURE !");

}

});

###3. get state of litebluetooth

BleLog.i(TAG, "liteBluetooth.getConnectionState: " + liteBluetooth.getConnectionState());

BleLog.i(TAG, "liteBluetooth isInScanning: " + liteBluetooth.isInScanning());

BleLog.i(TAG, "liteBluetooth isConnected: " + liteBluetooth.isConnected());

BleLog.i(TAG, "liteBluetooth isServiceDiscoered: " + liteBluetooth.isServiceDiscoered());

if (liteBluetooth.getConnectionState() >= LiteBluetooth.STATE_CONNECTING) {

BleLog.i(TAG, "lite bluetooth is in connecting or connected");

}

if (liteBluetooth.getConnectionState() == LiteBluetooth.STATE_SERVICES_DISCOVERED) {

BleLog.i(TAG, "lite bluetooth is in connected, services have been found");

}

###4. add(remove) new callback to an existing connection.

/**

* add(remove) new callback to an existing connection.

* One Device, One {@link LiteBluetooth}.

* But one device( {@link LiteBluetooth}) can add many callback {@link BluetoothGattCallback}

*

* {@link LiteBleGattCallback} is a extension of {@link BluetoothGattCallback}

*/

private void addNewCallbackToOneConnection() {

BluetoothGattCallback liteCallback = new BluetoothGattCallback() {

@Override

public void onConnectionStateChange(BluetoothGatt gatt, int status, int newState) {}

@Override

public void onCharacteristicChanged(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic) {

}

@Override

public void onCharacteristicWrite(BluetoothGatt gatt,

BluetoothGattCharacteristic characteristic, int status) {

}

@Override

public void onReadRemoteRssi(BluetoothGatt gatt, int rssi, int status) {}

};

if (liteBluetooth.isConnectingOrConnected()) {

liteBluetooth.addGattCallback(liteCallback);

liteBluetooth.removeGattCallback(liteCallback);

}

}

###5. refresh bluetooth device cache

liteBluetooth.refreshDeviceCache();

###6. close connection

if (liteBluetooth.isConnectingOrConnected()) {

liteBluetooth.closeBluetoothGatt();

}

###7. write data to characteritic

LiteBleConnector connector = liteBluetooth.newBleConnector();

connector.withUUIDString(UUID_SERVICE, UUID_CHAR_WRITE, null)

.writeCharacteristic(new byte[]{1, 2, 3}, new BleCharactCallback() {

@Override

public void onSuccess(BluetoothGattCharacteristic characteristic) {

BleLog.i(TAG, "Write Success, DATA: " + Arrays.toString(characteristic.getValue()));

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Write failure: " + exception);

bleExceptionHandler.handleException(exception);

}

});

###8. write data to descriptor

LiteBleConnector connector = liteBluetooth.newBleConnector();

connector.withUUIDString(UUID_SERVICE, UUID_CHAR_WRITE, UUID_DESCRIPTOR_WRITE)

.writeDescriptor(new byte[]{1, 2, 3}, new BleDescriptorCallback() {

@Override

public void onSuccess(BluetoothGattDescriptor descriptor) {

BleLog.i(TAG, "Write Success, DATA: " + Arrays.toString(descriptor.getValue()));

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Write failure: " + exception);

bleExceptionHandler.handleException(exception);

}

});

###9. read data from characteritic

LiteBleConnector connector = liteBluetooth.newBleConnector();

connector.withUUIDString(UUID_SERVICE, UUID_CHAR_READ, null)

.readCharacteristic(new BleCharactCallback() {

@Override

public void onSuccess(BluetoothGattCharacteristic characteristic) {

BleLog.i(TAG, "Read Success, DATA: " + Arrays.toString(characteristic.getValue()));

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Read failure: " + exception);

bleExceptionHandler.handleException(exception);

}

});

###10. enable notification of characteristic

LiteBleConnector connector = liteBluetooth.newBleConnector();

connector.withUUIDString(UUID_SERVICE, UUID_CHAR_READ, null)

.enableCharacteristicNotification(new BleCharactCallback() {

@Override

public void onSuccess(BluetoothGattCharacteristic characteristic) {

BleLog.i(TAG, "Notification characteristic Success, DATA: " + Arrays

.toString(characteristic.getValue()));

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Notification characteristic failure: " + exception);

bleExceptionHandler.handleException(exception);

}

});

###11. enable notification of descriptor

LiteBleConnector connector = liteBluetooth.newBleConnector();

connector.withUUIDString(UUID_SERVICE, UUID_CHAR_READ, UUID_DESCRIPTOR_READ)

.enableDescriptorNotification(new BleDescriptorCallback() {

@Override

public void onSuccess(BluetoothGattDescriptor descriptor) {

BleLog.i(TAG,

"Notification descriptor Success, DATA: " + Arrays.toString(descriptor.getValue()));

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Notification descriptor failure : " + exception);

bleExceptionHandler.handleException(exception);

}

});

###12. read RSSI of device

liteBluetooth.newBleConnector()

.readRemoteRssi(new BleRssiCallback() {

@Override

public void onSuccess(int rssi) {

BleLog.i(TAG, "Read Success, rssi: " + rssi);

}

@Override

public void onFailure(BleException exception) {

BleLog.i(TAG, "Read failure : " + exception);

bleExceptionHandler.handleException(exception);

}

});

##More Detail, See The Sample

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值