ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Android蓝牙低功耗(BLE)API尚未准备就绪

2019-11-22 07:27:10  阅读:330  来源: 互联网

标签:performance bluetooth-lowenergy gatt android


我正在开发一个健身应用程序,该应用程序支持两个BLE传感器(心律,步幅).我最终得到了两个有限制的服务(每个传感器一个),这些服务由我的主要活动调用和界定.它可以在带有KitKat的Nexus 7 II上运行.我花了几天时间尝试使应用程序达到稳定状态.全新重新启动后,Gatt连接和通知可以正常工作.我遇到的问题是,在一个或两个设备断开连接并需要重新连接后,设备又恢复了工作状态.由于其他人也曾报告过类似的问题,因此我开发并测试了各种方案,包括在活动重新启动时保持服务和连接畅通,关闭连接和服务器,然后重新启动,仅关闭而不断开连接,等待之前重新连接等.目前,使用一个传感器,我可以使应用程序大部分时间重新连接.使用两个传感器时,大多数情况下不会重新建立连接.考虑到每周都有许多新的BLE设备,Android BLE API是如此脆弱,真是太可惜了.我想知道是否还有其他人对多个BLE传感器感到幸运,是否愿意分享他们的方法来使它正常工作.

解决方法:

这不是一个非常有问题的问题,但是您的评论表明知道0x85的含义会有所帮助. Android BLE API取自Samsung的第二个BLE API,但并非Samsung定义的所有常量都可以实现.

0x85 = 133(您也可以在日志中看到)是GATT_ERROR.基本上,这意味着出了点问题,可能是外围设备超出了设备范围,或者是蓝牙芯片刚刚搞砸了.我发现在onConnectionStateChange的BluetoothGatt上调用connect()是一个不错的解决方案,因为它会等待一切整理好并在可能的情况下进行连接.

0x8D = 141 GATT_ALREADY_OPEN这很容易解释.

需要注意的另一件事是确保蓝牙发生的任何事情顺序发生.在上一个操作的结果发生之前,有多个线程将命令发送到BluetoothGatt往往不是一件好事.

标签:performance,bluetooth-lowenergy,gatt,android
来源: https://codeday.me/bug/20191122/2057989.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有