依赖
implementation 'com.clj.fastble:FastBleLib:2.3.4'
必要权限 ( 请注意,一定要保证定位权限已开启 )
<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
OK,现在开始写代码
一些全局变量
private UUID uuid_service;
private UUID uuid_chara;
private BluetoothGatt bluetoothGatt;
扫描蓝牙
/**
* 扫描蓝牙
* */
private void startScanBle(){
/**
*
* 在使用之前,需要事先调用初始化init(Application app)方法。此外,可以进行一些自定义的配置,
* 比如是否显示框架内部日志,重连次数和重连时间间隔,以及操作超时时间。
*
* */
BleManager.getInstance().init(getApplication());
BleManager.getInstance()
.enableLog(true)
.setReConnectCount(1, 5000)
.setSplitWriteNum(20)
.setConnectOverTime(10000)
.setOperateTimeout(5000);
/**
*
* 判断当前Android设备的蓝牙是否已经打开。
* 可以直接调用下面的判断方法来判断本机是否已经打开了蓝牙,如果没有,向用户抛出提示。
*
* */
if(!BleManager.getInstance().isBlueEnable()){
/**
* 开启蓝牙
* */
BleManager.getInstance().enableBluetooth();
}
/**
*
*配置扫描规则
* 扫描规则可以配置1个或多个,也可以不配置使用默认(扫描10秒)。
* 扫描的时候,会根据配置的过滤选项,对扫描到的设备进行过滤,结果返回过滤后的设备。
* 扫描时间配置为小于等于0,会实现无限扫描,直至调用BleManger.getInstance().cancelScan()来中止扫描。
*
* */
BleScanRuleConfig scanRuleConfig = new BleScanRuleConfig.Builder()
//.setServiceUuids(serviceUuids) // 只扫描指定的服务的设备,可选
//.setDeviceName(true, names) // 只扫描指定广播名的设备,可选
//.setDeviceMac(mac) // 只扫描指定mac的设备,可选
//.setAutoConnect(isAutoConnect) // 连接时的autoConnect参数,可选,默认false
.setScanTimeOut(10000) // 扫描超时时间,可选,默认10秒;小于等于0表示不限制扫描时间
.build();
BleManager.getInstance().initScanRule(scanRuleConfig);
/**
*
* 现在可以开始扫描了
*
* */
BleManager.getInstance().scan(new BleScanCallback() {
@Override
public void onScanFinished(List<BleDevice> scanResultList) {
// Toast.makeText(ScanBlueTooth.this,"扫描结束",Toast.LENGTH_LONG).show();
}
@Override
public void onScanStarted(boolean success) {
Toast.makeText(ScanBlueTooth.this,"开始寻找蓝牙",Toast.LENGTH_LONG).show();
}
@Override
public void onScanning(BleDevice bleDevice) {
// 如果用listview或recyclerview 显示可选择设备的话
// bluetoothAdapter.addItem(bleDevice);
}
});
}
扫描后肯定就是连接了
// bleDevice 就是 onScanning 中扫描到的设备
BleManager.getInstance().connect(bleDevice, new BleGattCallback() {
@Override
public void onStartConnect() {
// 开始连接,这里可以弹出一个 progressDialog
}
@Override
public void onConnectFail(BleDevice bleDevice, BleException exception) {
// 扫描失败,这里可以dimiss 掉 progressDialog
// 并且显示连接失败的具体原因
}
@Override
public void onConnectSuccess(BleDevice bleDevice, BluetoothGatt gatt, int status) {
// 连接成功后,就可以打开通知和发送指令了。
}
@Override
public void onDisConnected(boolean isActiveDisConnected, BleDevice device, BluetoothGatt gatt, int status) {
Toast.makeText(ScanBlueTooth.this,"连接中断",Toast.LENGTH_LONG).show();
}
});
获取uuid_service 和uuid_chara
bluetoothGatt = BleManager.getInstance().getBluetoothGatt(bleDevice);
/**
* 就是通过BluetoothGatt,查找出所有的Service和Characteristic的UUID:
* */
List<BluetoothGattService> serviceList = bluetoothGatt.getServices();
for (BluetoothGattService service : serviceList) {
uuid_service = service.getUuid();
List<BluetoothGattCharacteristic> characteristicList= service.getCharacteristics();
for(BluetoothGattCharacteristic characteristic : characteristicList) {
uuid_chara = characteristic.getUuid();
}
}
连接成功后打开通知,也就是用来接收来自蓝牙传输过来的内容
BleManager.getInstance().notify(
bleDevice,
uuid_service ,
uuid_chara,
new BleNotifyCallback() {
@Override
public void onNotifySuccess() {
// 打开通知操作成功
Log.i(TAG, "打开通知成功");
}
@Override
public void onNotifyFailure(BleException exception) {
// 打开通知操作失败
}
@Override
public void onCharacteristicChanged(byte[] data) {
// 打开通知后,设备发过来的数据将在这里出现
}
});
发送蓝牙指令
BleManager.getInstance().write(
bleDeviceBean.getBleDevice(),
bleDeviceBean.getUuid_service(),
bleDeviceBean.getUuid_write(),
"指令内容",
new BleWriteCallback() {
@Override
public void onWriteSuccess(int current, int total, byte[] justWrite) {
// justWrite 为指令内容
}
@Override
public void onWriteFailure(BleException exception) {
// 指令发送失败
Log.i(TAG,exception.getDescription());
}
});