zoukankan      html  css  js  c++  java
  • Android ble蓝牙使用注意

    以下均为自己在Android ble开发项目中遇到的问题

    1.尽量不要在BluetoothGattCallback里面的回调函数中执行读写通知操作,最多一个,因为例如在onServicesDiscovered回调函数中只会传一个写操作,不管里面有多少个,而通知如setCharacteristicNotification(characterist,true)也有写操作,所以如果需要同时执行多步征特操作时,不能在回调函数中执行,不然只会执行第一步特征操作。

    2.读写通知都是异步操作,但是一般必须一步一步地执行,只有当一个写特征操作完成并回调后才能执行下一个,不然只会执行最后一个,所以需要在两个写特征操作之间加一个睡眠时间如Thread.sleep(500),具体时间自己把握;

    3.很多蓝牙设备产家都会弄入自己的编码格式,所以有必要需要阅读对应品牌的通讯协议,因为发送的数据和接收的数据都需要根据产品的通讯协议来解读,可能在读取蓝牙设备的数据时需要先向设备发送命令,让其响应才行,有时还不只需要写一条命令,我遇到的问题是需要写两条不同的命令

    4.status为133时并不一定是GATT没有关闭,也有可能是蓝牙适配器没电了,如果软件代码自认为没问题,那就观察一下蓝牙是否正常工作,蓝牙灯是否有在闪,我遇到的是蓝牙灯没闪数据就读不到,然后status变为8并且再连接之后会出现133,只有当有电蓝牙灯亮时133才会消失且正常读取数据。

    5.使用characteristic.getValue()时得到的是一个byte[]数组,可以将其转化为十六进制字符串方便查看协议解码,在写特征操作设置值是应该传入byte[],因为自己认为写入的字符串是十六进制的,其实不是,应该将字符串转为byte[]

    6.蓝牙设备一般只能发送20个字节的数据,可能一次接收的数据不是完整的数据,需要将后面的数据连接起来构成一串完整的数据

    注:未经允许禁止转载!!!

  • 相关阅读:
    请教JDBC中的thin和OCI的区别
    ORACLE中查询被锁定的表,以及如何解锁
    oracle批量插入测试数据
    oracle查看用户表
    decode 函数及其用法
    oracle序列详解
    MySQL数据库远程连接开启方法
    CentOS下MySQL忘记root密码解决方法【转载】
    oracle实现同时多表插入
    MyCat:第七章:MyCAT的亿级别任务
  • 原文地址:https://www.cnblogs.com/klord/p/10220608.html
Copyright © 2011-2022 走看看