Android蓝牙聊天APP实战心得与流程设计

1 下载量 167 浏览量 更新于2024-08-30 收藏 64KB PDF 举报
本文档介绍了作者在三天内学习并实践Android蓝牙开发过程中的一些心得和体验,主要针对的是实现一个简单的一对一蓝牙聊天应用程序。作者强调了以下几个关键点: 1. 流程设计的重要性:在编写简单的蓝牙聊天应用时,首先要有一个清晰的整体流程图,这有助于指导代码编写,避免盲目地编写代码。 2. 日志与调试:在代码中添加足够的日志点是非常重要的,它们作为快速定位和调试问题的工具,帮助开发者追踪程序运行状态。 3. 面向对象编程和封装:作者引用了"Thinking in Java"中的理念,即区分可变和不可变数据,通过封装提高代码的可维护性和安全性。虽然这个概念在实际操作中可能需要深入理解,但它是实现代码模块化和高效性的基础。 4. 面向对象的处理:作者提到开始思考如何以面向对象的方式处理蓝牙聊天问题,这涉及到对象的设计、类的组织以及消息传递等原则。 5. 蓝牙功能实现:蓝牙聊天的核心功能包括一对一蓝牙连接和消息传输。这些功能涉及初始化蓝牙、开启服务器线程等待连接、配对获取地址、连接设备和开始通信等步骤。 6. 线程管理与安全:开发过程中要注意线程间的协调和同步,防止逻辑错误和并发问题。例如,在一对一直连模式下,需要确定服务器和客户端角色,并在连接建立后关闭非服务端的线程。 7. 代码示例:作者提供了一个名为`ConnectThread`的线程类片段,用于客户端通过蓝牙地址发起连接,显示了面向对象编程在实际操作中的应用。 通过这些心得和代码片段,读者可以了解到作者在Android蓝牙开发过程中遇到的问题、解决策略以及技术实践,对于想要学习蓝牙功能开发的读者来说,这是一个宝贵的参考资源。
2019-07-19 上传
BluetoothKit是一款功能强大的Android蓝牙通信框架,支持经典蓝牙和低功耗蓝牙设备混合扫描,提供了一系列简单易用的接口用于低功耗蓝牙设备的连接,数据读写,通知等。 特点 一、支持经典蓝牙和BLE蓝牙混合扫描,支持自定义扫描策略  作为智能家居平台,接入的设备包括经典蓝牙和BLE,因此扫描设备时需要两者混合进行,而设备扫描场景不同,扫描策略也会不一样,因此需要支持扫描策略可配置。 二、充分解决了Android中BLE兼容性和稳定性问题  Android系统对蓝牙4.0支持得并不完善,有许多bug, BluetoothKit很好地解决了其中大部分已知的问题。  三、简单易用,接口简洁明了  BluetoothKit采用异步串行化策略处理所有设备操作,并支持任务超时及出错重试。  技术 一、实现了一个完整的跨进程异步任务队列,支持任务超时、出错重试及防御队列溢出 二、拦截并Hook系统层蓝牙Binder,实现对所有蓝牙设备通信的监控,当同时连接设备数过多时会自动断掉活跃度最低的设备 三、整个框架封装在一个service中,可灵活指定service所在进程。通过client与service通信,client可源于多个不同进程,因此适用于多进程架构的app 四、屏蔽了接口异步回调可能持有调用端Activity引用导致的内存泄露 五、利用动态代理自动将所有操作封闭在工作线程,所以整个框架无锁 使用 // 首先,需要按如下方式初始化BluetoothClient: BluetoothClient mClient = BluetoothClient.getInstance(context); // 扫描设备:支持经典蓝牙和BLE设备混合扫描,可自由定制扫描策略如下: SearchRequest request = new SearchRequest.Builder() .searchBluetoothLeDevice(3000, 3) .searchBluetoothClassicDevice(5000) .searchBluetoothLeDevice(2000) .build(); mClient.search(request, new SearchResponse() { @Override public void onSearchStarted() { } @Override public void onDeviceFounded(SearchResult device) { } @Override public void onSearchStopped() { } @Override public void onSearchCanceled() { } }); // 停止蓝牙扫描 mClient.stopSearch(); // BLE设备连接 mClient.connect(MAC, new BleConnectResponse() { @Override public void onResponse(int code, Bundle data) { if (code == REQUEST_SUCCESS) { } } }); // BLE设备断开连接 mClient.disconnect(MAC); // 读取BLE设备 mClient.read(MAC, serviceUUID, characterUUID, new BleReadResponse() { @Override public void onResponse(int code, byte[] data) { if (code == REQUEST_SUCCESS) { } } }); // 写BLE设备 mClient.write(MAC, serviceUUID, characterUUID, bytes, new BleWriteResponse() { @Override public void onResponse(int code) { if (code == REQUEST_SUCCESS) { } } }); // 打开设备通知 mClient.notify(MAC, serviceUUID, characterUUID, new BleNotifyResponse() { @Override public void onNotify(UUID service, UUID character, byte[] value) { } @Override public void onResponse(int code) { if (code == REQUEST_SUCCESS) { } } }); // 关闭设备通知 mClient.unnotify(MAC, serviceUUID, characterUUID, new BleUnnotifyResponse() { @Override public void onResponse(int code) { if (code == REQUEST_SUCCESS) { } } }); // 读取rssi mClient.readRssi(MAC, new BleReadRssiResponse() { @Override public void onResponse(int code, Integer rssi) { if (code == REQUEST_SUCCESS) { } } }); 标签:BluetoothKit