BLE特性更改后的回调仅在写入

时间:2016-07-08 13:06:15

标签: c# bluetooth notifications bluetooth-lowenergy gatt

我尝试使用典型方法订阅BLE特征通知:

stCharacteristic = stService.GetCharacteristics(stCharacteristicGUID)[0];
await stCharacteristic.WriteClientCharacteristicConfigurationDescriptorAsync(GattClientCharacteristicConfigurationDescriptorValue.Notify);
stCharacteristic.ValueChanged += stData_ValueChanged;

回调函数也有标准格式:

async void stData_ValueChanged(GattCharacteristic sender, GattValueChangedEventArgs args)
{
    var values = (await sender.ReadValueAsync()).Value.ToArray();
}

问题是当BLE设备改变特征值时,并不总是调用回调。当我向特征写入内容并且设备在响应中写入内容时,则调用回调。但是如果设备只是自己写入特性,则不会调用回调。有趣的是,数据不会丢失。当我再次写一些内容时,我会在回调中多次调用BLE设备发送的所有数据。换句话说,它看起来像Windows或.NET Framework缓存后续传入的数据,直到写入。在写入后,第一个特征变化导致回调被触发。

  • 传入数据 - 无回拨
  • 发送数据
  • 传入数据 - 两次回调!
  • 发送数据
  • 传入数据 - 一次回调
  • 传入数据
  • 传入数据
  • 传入数据
  • 发送数据 - 三个回调!

Windows 10,VS2015

2 个答案:

答案 0 :(得分:0)

您不必阅读ValueChanged回调中的值。该值已存在于GattValueChangedEventArgs中。

除此之外 - 您的处理程序应该直接调用,而不是在写入之后。你能看到你的设备是否在通知之间断开/连接了吗?

答案 1 :(得分:0)

事实证明这是Windows 10问题。而在Windows 10.0.15063及更新版本(如10.0.16251)上,情况更糟 - 根本没有回调。幸运的是,有一个简单的解决方法,需要添加两个注册表项。这是.reg文件:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\AppID\{C6BFD646-3DF0-4DE5-B7AF-5FFFACB844A5}]
"AccessPermission"=hex:01,00,04,80,9c,00,00,00,ac,00,00,00,00,00,00,00,14,00,\
  00,00,02,00,88,00,06,00,00,00,00,00,14,00,07,00,00,00,01,01,00,00,00,00,00,\
  05,0a,00,00,00,00,00,14,00,03,00,00,00,01,01,00,00,00,00,00,05,12,00,00,00,\
  00,00,18,00,07,00,00,00,01,02,00,00,00,00,00,05,20,00,00,00,20,02,00,00,00,\
  00,18,00,03,00,00,00,01,02,00,00,00,00,00,0f,02,00,00,00,01,00,00,00,00,00,\
  14,00,03,00,00,00,01,01,00,00,00,00,00,05,13,00,00,00,00,00,14,00,03,00,00,\
  00,01,01,00,00,00,00,00,05,14,00,00,00,01,02,00,00,00,00,00,05,20,00,00,00,\
  20,02,00,00,01,02,00,00,00,00,00,05,20,00,00,00,20,02,00,00

[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\AppID\YOURAPP.exe]
"AppID"="{C6BFD646-3DF0-4DE5-B7AF-5FFFACB844A5}"

将YOURAPP.exe更改为您的exe文件名。 GUID可以更改或保持原样。应用此.reg文件后,每次都会立即调用回调,并且收到的通知非常好。

在撰写此答案时,微软正致力于永久修复。解决方法和讨论在这里:https://social.msdn.microsoft.com/Forums/en-US/58da3fdb-a0e1-4161-8af3-778b6839f4e1/bluetooth-bluetoothledevicefromidasync-does-not-complete-on-10015063?forum=wdk