1.bluetooth �ٷ�Դ��
2....Ble蓝牙开发Demo示例–扫描,源码连接,发送和接收数据,分包解包(附源码...
3.蓝牙RFCOMM协议实现
4.Androidå¼åä¹èçï¼Bluetoothï¼
5.Bluez中hcitool工具使用
bluetooth �ٷ�Դ��
久未更新的账号似乎被遗忘,但无论如何,源码我依然是源码那个在大明湖畔的程序媛饭饭,今天就聊聊蓝牙学习的源码问题。
面对同行关于蓝牙学习的源码询问,实话实说,源码懿古今源码网我并非专家,源码因为也是源码自学而来,学习之路并不系统。源码蓝牙涉及的源码范围广泛,包括上层接口实现、源码功能设计到底层协议规范,源码每个环节都复杂而深奥,源码我无法给出全面的源码解答。
在分享知识时,源码我主要依赖自己对蓝牙源码的解析和蓝牙技术联盟(SIG)的官方资料。如果读者能指出我文章中的错误,那将是均线源码我最大的感激。记住,学习蓝牙需要耐心和毅力,从基础开始,一步步来,不要急于求成,因为心急吃不了热豆腐。
从用户角度看,蓝牙是一种无线通信技术,提供数据传输和连接功能。当你在设置中打开或关闭蓝牙,其实触发了系统内的一个复杂流程。系统中的Bluetooth应用和进程在开机时就已经准备就绪,特别是BluetoothManagerService,它在SystemServer的启动过程中扮演重要角色。
当设置应用调用开启蓝牙,它会通过System API调用Bluetooth服务,接着是刮源码JNI和Binder的协作,激活蓝牙协议栈。这个过程只展示了上层代码的调用逻辑,实际操作涉及更深层次的准备工作,比如在系统启动时初始化服务并进行相应设置。
总的来说,蓝牙服务的启动是一个精心设计的过程,包括初始化服务实例、注册内容观察者和广播接收器,以及处理飞行模式状态变化等。当用户在设置中操作时,这些服务会根据特定条件恢复或开启蓝牙,确保用户体验的连贯性。
...Ble蓝牙开发Demo示例–扫描,连接,发送和接收数据,分包解包(附源码...
万物互联的物联网时代已经到来,低功耗蓝牙BLE(Bluetooth Low Energy)技术在推动这一进程中起着至关重要的作用。近期,我抽出时间整理了BLE蓝牙开发的要点。本文将详细介绍Android平台下BLE蓝牙通讯的源码侠客户端和服务端开发,包括扫描、连接、发送和接收数据、分包解包等环节,并提供完整的源码示例。
在Android开发中,BLE蓝牙通讯涉及客户端和服务端两个主要部分。客户端负责开启蓝牙、扫描设备、建立连接、发送和接收数据。服务端则负责初始化广播数据、启动广播、配置服务以及处理客户端的连接请求。在开发过程中,常见的问题包括不同版本Android或不同手机之间的适配问题、避免BLE连接时的微信公众号 源码错误、以及处理单次写数据大小限制等。
BLE协议基于GATT(Generic Attribute Profile),相关的类主要集中在`android.bluetooth`和`android.bluetooth.le`包中。这些类包括`BluetoothGattService`、`BluetoothGattCharacteristic`、`BluetoothGattDescriptor`和`BluetoothGatt`等。客户端的核心是`BluetoothGatt`,而服务端的核心是`BluetoothGattServer`和`BluetoothLeAdvertiser`。数据传输的核心则是`BluetoothGattCharacteristic`和`BluetoothGattDescriptor`。
开发步骤将从客户端和服务端两个角度详细阐述。在开始蓝牙开发之前,需要在`AndroidManifest.xml`中声明必要的权限,并在代码中请求打开蓝牙。搜索BLE设备后,根据设备名称确定目标设备,并启动连接过程。连接成功后,通过`BluetoothGattCallback`进行数据通信。
在通信过程中,可能会遇到数据分包和组包的需求,因为BLE单次写入数据限制为字节。解决这一问题的方法是定义分包协议,如将数据包和非数据包分开,并通过特定的序号来识别数据包的顺序。
完整的开发流程包括定义通讯协议、封装发送和接收数据的接口、解析数据包以及进行业务逻辑处理。在实际开发中,还需要注意Android版本适配和不同ROM机型的权限问题。
本文提供的源码示例已上传至CSDN,可供参考。开发者需要耐心分析问题,不断实践,以解决蓝牙开发中可能遇到的挑战。
蓝牙RFCOMM协议实现
基于RFCOMM的通信demo是一个允许两个安卓设备进行双向蓝牙数据交互的程序,该程序通过展示蓝牙API功能实现基本的蓝牙通信。以下是实现步骤及关键代码分析:
步骤一:扫描与发现周围可用的蓝牙设备。通过蓝牙API功能,扫描并展示周围可用的蓝牙设备,同时获得BluetoothDevice对象,用于后续建立连接。
步骤二:发起连接。单独启动线程发起连接,当点击已发现的设备,传入设备对象,线程启动尝试连接。关键代码为:device.createRfcommSocketToServiceRecord(MY_UUID_SECURE)建立与选定设备的RFCOMM通道,通过mmSocket.connect()发起连接,服务端设备响应连接请求并获得socket连接对象。
步骤三:连接管理。在发起连接后,新起线程用于管理连接,包括发送与接收数据。
步骤四:响应连接。客户端设备发起连接并管理连接,服务端设备需响应连接请求。可通过监听特定服务的连接请求实现,使用代码:mAdapter.listenUsingRfcommWithServiceRecord(NAME_SECURE,MY_UUID_SECURE)监听连接请求,socket = mmServerSocket.accept()响应请求返回socket连接对象,启动连接管理线程进行数据交互。
总结:该demo实现了简单的字符串数据收发,没有进行数据分类、分包处理。后期可考虑改进。
源码获取:通过私信或评论方式。
Androidå¼åä¹èçï¼Bluetoothï¼
å¨ä¸ä¸ç¯ä¸æä»ç»äºWifiä¸ç½ç»è¿æ¥å¤çAndroidå¼åä¹WiFiä¸ç½ç»è¿æ¥å¤ç
ä¸é¢ï¼æ¥ç»§ç»è¯´è¯´Androidä¸èççåºæ¬ä½¿ç¨ã
Bluetoothæ¯ç®å使ç¨çæ广æ³çæ 线é讯åè®®ä¹ä¸,主è¦é对çè·ç¦»è®¾å¤é讯ï¼ç±³ï¼ï¼å¸¸ç¨äºè¿æ¥è³æºãé¼ æ å移å¨é讯设å¤çã
å¼å¾ä¸æçæ¯ï¼
android4.2æ°å¢äºé¨åæ°åè½ï¼ä½æ¯å¯¹äºBluetoothçæç人æ许å¼å§å¤´ç¼äºï¼é£å°±æ¯Android4.2å¼å ¥äºä¸ä¸ªæ°çèçåè®®æ éBLEãè°·æåBroadcomä¹é´çåä½ï¼å¼åæ°çèçåè®®æ ï¼å代äºåºäºå æ çBluezãå æ¤å¸åºä¸åºç°äºè设å¤çå ¼å®¹é®é¢ï¼å¾å¤èç设å¤å¨android4.2ææºä¸ä¸è½æ£å¸¸ä½¿ç¨ã
BluetoothAdapterç®åç¹æ¥è¯´å°±æ¯ä»£è¡¨äºæ¬è®¾å¤(ææºãçµèç)çèçéé å¨å¯¹è±¡ã
firstï¼we need permission
è¦æä½èçï¼å è¦å¨AndroidManifest.xmléå å ¥æé
**ä¸é¢æ¥ççå¦ä½ä½¿ç¨èçã **âââ
****Demo已就绪ï¼
è¿åå¼ï¼å¦æ设å¤å ·å¤èçåè½ï¼è¿åBluetoothAdapter å®ä¾ï¼å¦åï¼è¿ånull对象ã
æå¼èç设å¤çæ¹å¼ï¼
1.ç´æ¥è°ç¨å½æ°enable()å»æå¼èçè®¾å¤ ï¼
2.ç³»ç»APIå»æå¼èç设å¤ï¼è¯¥æ¹å¼ä¼å¼¹åºä¸ä¸ªå¯¹è¯æ¡æ ·å¼çActivityä¾ç¨æ·éæ©æ¯å¦æå¼èç设å¤ã
注æï¼1.å¦æèçå·²ç»å¼å¯ï¼ä¸ä¼å¼¹åºè¯¥Activityçé¢ã2.å¨ç®å大å¤æ°Androidææºä¸ï¼æ¯ä¸æ¯æå¨é£è¡æ¨¡å¼ä¸å¼å¯èççãå¦æèçå·²ç»å¼å¯ï¼é£ä¹èççå¼å ³ ,ç¶æä¼éçé£è¡æ¨¡å¼çç¶æèåçæ¹åã
1. æç´¢èç设å¤
使ç¨BluetoothAdapterçstartDiscovery()æ¹æ³æ¥æç´¢èç设å¤
startDiscovery()æ¹æ³æ¯ä¸ä¸ªå¼æ¥æ¹æ³ï¼è°ç¨åä¼ç«å³è¿åã该æ¹æ³ä¼è¿è¡å¯¹å ¶ä»èç设å¤çæç´¢ï¼è¯¥è¿ç¨ä¼æç»ç§ã该æ¹æ³è°ç¨åï¼æç´¢è¿ç¨å®é ä¸æ¯å¨ä¸ä¸ªSystem Serviceä¸è¿è¡çï¼æ以å¯ä»¥è°ç¨cancelDiscovery()æ¹æ³æ¥åæ¢æç´¢ï¼è¯¥æ¹æ³å¯ä»¥å¨æªæ§è¡discovery请æ±æ¶è°ç¨ï¼ã
ç³»ç»å¼å§æç´¢èç设å¤
^( * ï¿£(oo)ï¿£ ) ^ ç³»ç»ä¼åé以ä¸ä¸ä¸ªå¹¿æï¼
2.æ«æ设å¤
3.å®ä¹å¹¿ææ¥æ¶å¨æ¥æ¶æç´¢ç»æ
4.注å广æ
è·åéè¿çèç设å¤
第ä¸æ¥å»ºç«è¿æ¥ï¼é¦å Android sdkï¼2.0以ä¸çæ¬ï¼æ¯æçèçè¿æ¥æ¯éè¿BluetoothSocket建ç«è¿æ¥ï¼æå¡ç«¯BluetoothServerSocketå客æ·ç«¯ï¼BluetoothSocketï¼éæå®åæ ·çUUIDï¼æè½å»ºç«è¿æ¥ï¼å 为建ç«è¿æ¥çæ¹æ³ä¼é»å¡çº¿ç¨ï¼æ以æå¡å¨ç«¯å客æ·ç«¯é½åºå¯å¨æ°çº¿ç¨è¿æ¥ã
ï¼è¿éçæå¡ç«¯å客æ·ç«¯æ¯ç¸å¯¹æ¥è¯´çï¼
两个èç设å¤ä¹é´çè¿æ¥ï¼åå¿ é¡»å®ç°æå¡ç«¯ä¸å®¢æ·ç«¯çæºå¶ã
å½ä¸¤ä¸ªè®¾å¤å¨åä¸ä¸ªRFCOMM channelä¸åå«æ¥æä¸ä¸ªè¿æ¥çBluetoothSocketï¼è¿ä¸¤ä¸ªè®¾å¤æå¯ä»¥è¯´æ¯å»ºç«äºè¿æ¥ã
æå¡ç«¯è®¾å¤ä¸å®¢æ·ç«¯è®¾å¤è·åBluetoothSocketçéå¾æ¯ä¸åçã
1ï¼æå¡ç«¯è®¾å¤æ¯éè¿acceptedä¸ä¸ªincoming connectionæ¥è·åçï¼
2ï¼å®¢æ·ç«¯è®¾å¤åæ¯éè¿æå¼ä¸ä¸ªå°æå¡ç«¯çRFCOMM channelæ¥è·åçã
æå¡ç«¯
éè¿è°ç¨BluetoothAdapterçlistenUsingRfcommWithServiceRecord(String, UUID)æ¹æ³æ¥è·åBluetoothServerSocketï¼UUIDç¨äºå®¢æ·ç«¯ä¸æå¡ç«¯ä¹é´çé 对ï¼
客æ·ç«¯
è°ç¨BluetoothServiceçcreateRfcommSocketToServiceRecord(UUID)æ¹æ³è·åBluetoothSocketï¼è¯¥UUIDåºè¯¥åäºæå¡ç«¯çUUIDï¼ã
è°ç¨BluetoothSocketçconnect()æ¹æ³ï¼è¯¥æ¹æ³ä¸ºblockæ¹æ³ï¼ï¼å¦æUUIDåæå¡ç«¯çUUIDå¹é ï¼å¹¶ä¸è¿æ¥è¢«æå¡ç«¯acceptï¼åconnect()æ¹æ³è¿åã
æ°æ®ä¼ éï¼éè¿ä»¥ä¸æä½ï¼å°±å·²ç»å»ºç«çBluetoothSocketè¿æ¥äºï¼æ°æ®ä¼ éæ éæ¯éè¿æµçå½¢å¼
è·åæµ
该类就æ¯å ³äºè¿ç¨èç设å¤çä¸ä¸ªæè¿°ãéè¿å®å¯ä»¥åæ¬å°èç设å¤---BluetoothAdapterè¿æ¥éä¿¡ã
好å¤ä¸è¥¿æä¹ä¸ç¥éæä¹æè¿°ï¼ä¸é¢ç»åºDemoï¼
å好æåå¦ä¹ çå°ä¼ä¼´é®æListViewæä¹ç¨ï¼é£æå°±ç¨ListViewã
æºç ï¼
RairDemo
GitHub: /Rairmmd/android-demo
Coding: /u/Rair/p/RairDemo/git
Bluez中hcitool工具使用
Bluez中hcitool工具已逐渐被Bluetoothctl取代,官方建议使用Bluetoothctl,因其功能更加强大且操作更便捷。hcitool直接与底层hci接口通信,源码显示其函数命名均以hci开头。
hcitool中包含专门用于扫描低功耗设备的命令lescan。对比源码,其函数hci_le_set_scan_parameters与Bluetooth技术规格要求一致。
扫描类型参数scantype定义为被动或主动扫描,主动扫描会发出扫描包,而被动扫描则不发出包。scantype参数决定扫描频率和窗口大小,通过调整scaninterval和scanwindow,可实现低功耗扫描。
ownaddresstype参数设置为主动扫描包中地址的性质,默认设置为random,不选择public,可能为保护隐私,避免泄露自身MAC信息。
通过设置filter参数,可选择只上报白名单中的设备,增强设备选择的针对性。
所有配置通过hci_send_req命令发送至底层,底层硬件接收到命令后接收包并生成HCI_LE_Advertising_Report事件。
使用print_advertising_devices函数获取并打印出扫描到的设备,该函数不断捕获HCI_LE_Advertising_Report事件,解析数据并打印出mac地址和外设名称,同时也可能包含RSSI数据。
部分名称显示为unknown,可能是因为外设广播包中缺少AD type为名称的字段。