gpt4 book ai didi

android - 带有BLE的Android应用架构

转载 作者:太空狗 更新时间:2023-10-29 15:44:22 24 4
gpt4 key购买 nike

我正在用android的ble api开发一个android应用程序。我的应用程序需要连接到BLE设备,并保持连接,只要它在范围内并打开。我需要从中读取数据,并将数据写入其中。
我试图遵循mvp架构模式,而不是严格地,因为活动是起点。但是无论如何,我想知道我应该把蓝牙的交互放在哪里?我正在寻找下列问题的答案。我已经搜索了stackoverflow,但找不到我要找的东西。
它应该像googlesample ble app中那样在绑定到ui的服务中吗?但是,我认为这会破坏整个mvp架构。
它应该是一个有边界的服务吗?如果没有,那么实现服务的最佳方式是什么?在我看来,如果它没有绑定到视图,并且有一个来自后台服务的回调来在ui上显示某些内容,那么就有可能出现未定义的行为。
谁应该启动蓝牙交互?应用程序类还是一些活动?
我正在寻找主要的建筑指导,最好的方式去开发这个应用程序。

最佳答案

因为您有蓝牙连接应该在后台工作的要求,所以在应用程序进程中运行的地方应该有一个“AA>”。这将确保您的应用程序进程保持活跃,但需要图标显示在电话/平板电脑的顶部栏中。
你是否真的把你的ble代码放在这个服务类中并不重要。
当然有很多方法可以实现好的架构,但这里是我的方法。
我的方法是拥有一个处理你所有的BLE扫描、连接和GATT交互的独生子类(从现在起称为Manager)。由于一些ble操作需要android上下文,一个好的方法是使用应用程序上下文作为上下文。要么跟随AA>能够在任何时候获取上下文,要么从应用程序类的子类和它的onCreate调用管理器中的一些初始化方法,并传递上下文。现在,您可以将所有ble功能与android服务/活动/应用程序完全分离。我真的不明白使用有界服务等的意义,只要你把所有的东西都放在同一个过程中。
为了实现扫描功能,可以在管理器中创建一个创建扫描器对象的方法。将扫描仪类作为包装器写入Android的BLE扫描仪,并公开启动/停止扫描的方法。当创建扫描器时,该方法还应该将接口用作回调(设备报告和错误)的参数。这个类现在可以用于例如活动。只需确保扫描器在活动的onStop方法中停止,以避免对象泄漏。
有一个打包的自定义扫描器对象,而不是在活动中直接使用Android的BLE扫描API的原因有很多。首先,您可以对广告包进行适当的过滤和处理,以便处理您的外围设备类型,并可以在自定义广告报告回调中显示高级别参数(从广告数据中解码)。当蓝牙开始/停止/重新启动时,管理者也应该收听广播,并跟踪所有启动的扫描仪,这样当蓝牙重新启动时,扫描仪就无缝地重新启动(如果你想要这个功能的话)。您可能还希望跟踪所有扫描开始/停止的时间戳,这样您就可以处理NuGAT中的新限制,将其限制为每30秒5次扫描。
当您想连接到外围设备时,使用类似的方法。例如,您可以让管理器创建设备对象,这些对象具有启动/停止连接的方法,以及用于报告事件的回调接口。对于每个支持的特性(例如读取一些远程值),您应该公开一种方法,该方法启动请求并在结果到达时调用一个回调。然后你的经理和设备类负责关贸总协定的东西(包括排队所有你的关贸总协定要求,所以你只有一个杰出的关贸总协定操作一次)。只要确保在不需要结果时始终可以中止或忽略结果,例如,如果调用了活动的onStoponDestroy方法。
由于您可能希望在设备断开连接时自动重新连接,因此在建立连接时应使用autoConnect标志并将其设置为true,这可以确保这一点。再次,管理者应跟踪所有活动设备对象,并在重新启动蓝牙时自动重新创建BlueToToGATT对象。
能够显示不同类型的UI素材,例如当蓝牙关闭时,在活动中自动显示警告消息并在蓝牙打开时删除它,您应该能够向监听器注册监听器。在您的管理器中有一个方法来注册/取消注册侦听器(这实际上是一个回调)对象,跟踪所有侦听器,当蓝牙状态发生变化时,调用所有侦听器。然后在你的活动onStart你注册一个侦听器,在onStop你注销它。在适用的情况下,您可以对设备的BLE通知使用类似的方法。
剩下的就是如何处理不同的线程。正如您可能知道的,大多数来自android的api的ble回调都发生在绑定线程上,因此您可能不会从它们更新ui。如果你在应用程序中不使用除了主线程之外的任何东西,你可以把管理器中的回调全部调用到主线程中,或者当Android的BLE栈返回时,直接移动到主线程(但是然后注意像AA>之类的东西)。只要确保你从未接触到相同的变量从不同的线程。
另外,如果您的目标是API23或更高版本,则需要用户界面代码来允许用户对位置授予权限,以便能够启动扫描。我建议您在ui代码中而不是在管理器中实现这一点,或者在管理器中实现一些“包装器”或帮助器方法来实现这一点。

关于android - 带有BLE的Android应用架构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48039177/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com