如何用蓝牙网关跟蓝牙设备建立服务链接并读取数据

如何用蓝牙网关跟蓝牙设备建立服务链接并读取数据


首先我们先需要知道,蓝牙服务分为两个类型16bit和128bit,16bit服务其实就是蓝牙联盟官方规定的服务,128bit服务就是留给厂商自己定义的服务,因为需要加入厂商代码所以就变成了128bit,为了两种服务兼容,16bit服务也有个基础的代码,下面的截图中可以看到,金桔蓝牙网关对这两种服务都能进行连接,下面分别进行说明。

蓝牙标准服务类型(16bit)

安卓手机看到的此类型服务为0000xxxx-0000-1000-8000-00805F9B34FB(蓝牙联盟的基础代码),例如,我们服务uuid为0x0001,写入服务为0x0004,通知服务为0x0005,苹果手机看起是这样的:
在这里插入图片描述
安卓手机看起来是这样的:
在这里插入图片描述
这种服务的连接在金桔ACserver中需要这样配置:
在这里插入图片描述
点击连接后,右边事件列表中:
在这里插入图片描述
有显示连接状态。

这样就是已经可以成功连接设备。
如果需要用命令进行连接,需要发送下面这样命令:

[ 
    { 
        "command": "41", 
        "gatewayId": "10000060", 
        "target": "gateway", 
        "contentType": "byte", 
        "content": "10,00,00,63,42,42,10,00,00,00,01,00,01,04,00,05,00"
    }
]

在这里插入图片描述
发送连接命令后,会收到蓝牙连接成功的消息。

另外注意,如果要是服务的UUID是标准的蓝牙服务,安卓上看到的也是2个字节的服务UUID
在这里插入图片描述

这种不影响正常通信,只是填写的服务填上标准的UUID即可。

厂商服务类型(128bit)

此类型服务,需要有厂商自定义的UUID,即16字节的UUID。
例如,我们建立一个厂商服务 9E,CA,DC,24,0E,E5,A9,E0,93,F3,A3,B5,00,00,40,6E(注意,手机看到的正好与此顺序相反,第12,13字节空出来留着填服务UUID)服务UUID为0xF001,写入服务为0x0004,通知服务为0x0005,苹果手机上看到的服务类型为:

在这里插入图片描述
安卓手机看到的是这样的:
在这里插入图片描述
跟苹果是一致的,我们用金桔网关连接时这样填写金桔ACserver:
在这里插入图片描述
点击连接后即可连接成功,连接信息注意观察右边的事件列表,注意不要刷新页面。

如果使用命令建立蓝牙连接,发送的命令是这样的。

[ 
    { 
        "command": "41", 
        "gatewayId": "10000060", 
        "target": "gateway", 
        "contentType": "byte", 
        "content": "10,00,00,61,42,42,10,00,00,00,01,f0,02,04,00,05,00,9E,CA,DC,24,0E,E5,A9,E0,93,F3,A3,B5,00,00,40,6E"
    }
]
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 平台上,可以通过 BluetoothDevice 类的 getBluetoothClass() 方法获取蓝牙设备的类型。该方法返回一个 BluetoothClass 对象,该对象包含了蓝牙设备的类型信息,如手机、音频设备、电脑等。 下面是一个示例代码,演示如何获取蓝牙连接设备的类型: ```java BluetoothDevice device = ...; // 获取已连接的蓝牙设备 BluetoothClass btClass = device.getBluetoothClass(); int deviceType = btClass.getDeviceClass(); switch (deviceType) { case BluetoothClass.Device.AUDIO_VIDEO_CAMCORDER: // 音视频设备,如摄像机 break; case BluetoothClass.Device.AUDIO_VIDEO_HEADPHONES: // 音视频设备,如耳机 break; case BluetoothClass.Device.AUDIO_VIDEO_HIFI_AUDIO: // 音频设备,如音响 break; case BluetoothClass.Device.AUDIO_VIDEO_LOUDSPEAKER: // 音视频设备,如扬声器 break; case BluetoothClass.Device.AUDIO_VIDEO_MICROPHONE: // 音视频设备,如麦克风 break; case BluetoothClass.Device.AUDIO_VIDEO_PORTABLE_AUDIO: // 音频设备,如便携式音箱 break; case BluetoothClass.Device.AUDIO_VIDEO_SET_TOP_BOX: // 音视频设备,如机顶盒 break; case BluetoothClass.Device.AUDIO_VIDEO_UNCATEGORIZED: // 未分类的音视频设备 break; case BluetoothClass.Device.AUDIO_VIDEO_VCR: // 音视频设备,如录像机 break; case BluetoothClass.Device.AUDIO_VIDEO_VIDEO_CAMERA: // 音视频设备,如摄像头 break; case BluetoothClass.Device.AUDIO_VIDEO_VIDEO_CONFERENCING: // 音视频设备,如视频会议设备 break; case BluetoothClass.Device.AUDIO_VIDEO_VIDEO_DISPLAY_AND_LOUDSPEAKER: // 音视频设备,如显示器和扬声器一体机 break; case BluetoothClass.Device.AUDIO_VIDEO_VIDEO_GAMING_TOY: // 音视频设备,如游戏手柄 break; case BluetoothClass.Device.AUDIO_VIDEO_VIDEO_MONITOR: // 音视频设备,如监视器 break; case BluetoothClass.Device.AUDIO_VIDEO_WEARABLE_HEADSET: // 音视频设备,如可穿戴式耳机 break; case BluetoothClass.Device.COMPUTER_DESKTOP: // 电脑,如台式机 break; case BluetoothClass.Device.COMPUTER_HANDHELD_PC_PDA: // 电脑,如手持电脑和PDA break; case BluetoothClass.Device.COMPUTER_LAPTOP: // 电脑,如笔记本电脑 break; case BluetoothClass.Device.COMPUTER_PALM_SIZE_PC_PDA: // 电脑,如掌上电脑和PDA break; case BluetoothClass.Device.COMPUTER_SERVER: // 电脑,如服务器 break; case BluetoothClass.Device.COMPUTER_UNCATEGORIZED: // 未分类的电脑设备 break; case BluetoothClass.Device.COMPUTER_WEARABLE: // 电脑,如可穿戴式电脑 break; case BluetoothClass.Device.HEALTH_BLOOD_PRESSURE: // 健康设备,如血压计 break; case BluetoothClass.Device.HEALTH_DATA_DISPLAY: // 健康设备,如数据显示器 break; case BluetoothClass.Device.HEALTH_GLUCOSE: // 健康设备,如血糖仪 break; case BluetoothClass.Device.HEALTH_PULSE_OXIMETER: // 健康设备,如脉搏血氧仪 break; case BluetoothClass.Device.HEALTH_PULSE_RATE: // 健康设备,如脉搏计 break; case BluetoothClass.Device.HEALTH_THERMOMETER: // 健康设备,如体温计 break; case BluetoothClass.Device.HEALTH_UNCATEGORIZED: // 未分类的健康设备 break; case BluetoothClass.Device.HEALTH_WEIGHING: // 健康设备,如体重秤 break; case BluetoothClass.Device.PHONE_CELLULAR: // 手机,如手机 break; case BluetoothClass.Device.PHONE_CORDLESS: // 电话,如无绳电话 break; case BluetoothClass.Device.PHONE_ISDN: // 电话,如ISDN终端适配器 break; case BluetoothClass.Device.PHONE_MODEM_OR_GATEWAY: // 电话,如调制解调器或网关 break; case BluetoothClass.Device.PHONE_SMART: // 手机,如智能手机 break; case BluetoothClass.Device.PHONE_UNCATEGORIZED: // 未分类的电话设备 break; case BluetoothClass.Device.TOY_CONTROLLER: // 玩具设备,如遥控器 break; case BluetoothClass.Device.TOY_DOLL_ACTION_FIGURE: // 玩具设备,如玩偶 break; case BluetoothClass.Device.TOY_GAME: // 玩具设备,如游戏机 break; case BluetoothClass.Device.TOY_ROBOT: // 玩具设备,如机器人 break; case BluetoothClass.Device.TOY_UNCATEGORIZED: // 未分类的玩具设备 break; case BluetoothClass.Device.TOY_VEHICLE: // 玩具设备,如遥控车 break; case BluetoothClass.Device.WEARABLE_GLASSES: // 可穿戴设备,如智能眼镜 break; case BluetoothClass.Device.WEARABLE_HELMET: // 可穿戴设备,如头盔 break; case BluetoothClass.Device.WEARABLE_JACKET: // 可穿戴设备,如智能上衣 break; case BluetoothClass.Device.WEARABLE_PAGER: // 可穿戴设备,如寻呼机 break; case BluetoothClass.Device.WEARABLE_UNCATEGORIZED: // 未分类的可穿戴设备 break; case BluetoothClass.Device.WEARABLE_WRIST_WATCH: // 可穿戴设备,如智能手表 break; default: // 未知设备 break; } ``` 注意,BluetoothClass 中的设备类型分为三个级别:主设备类型、次设备类型和服务类别。getDeviceClass() 方法返回的是主设备类型,如果需要获取更详细的信息,可以使用 BluetoothClass 的其他方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值