BleReader.Net
1.0.0
.NET을 사용하여 Bluetooth LE 장치의 제조업체 데이터를 읽기 위해 만든 간단한 래퍼.
현재 DBUS 및 Bluez (Dotnet-Bluez 사용)를 사용하여 Linux를 지원합니다. 원시 제조업체 데이터를 제공하는 것 외에도 특정 장치에 대한 구문 분석 데이터를 제공합니다 (현재 Ruuvitag 만 지원).
Nuget 패키지로 제공 :
dotnet add package BleReader.Net
Ruuvitag 데이터 가져 오기 :
var adapterName = "hci0";
var scanDurationSeconds = 5;
var ruuviMacAddress = "12:34:56:78:90:AB";
IBleReader reader = new BleReader(new DotNetBlueZService());
await reader.ScanAsync(adapterName, scanDurationSeconds);
var ruuviTag = await reader.GetManufacturerDataAsync<RuuviTag>(ruuviMacAddress);
if (ruuviTag != null)
{
var dataAsJson = JsonSerializer.Serialize(ruuviTag, new JsonSerializerOptions() { WriteIndented = true });
Console.WriteLine($"Data: {dataAsJson}");
}
else
{
Console.WriteLine("No RuuviTag found");
}
산출:
Data: {
"DataFormat": 5,
"Humidity": 27.495,
"Temperature": 18.1,
"AirPressure": 1006.94,
"AccelerationX": -0.004,
"AccelerationY": -0.012,
"AccelerationZ": 1.032,
"BatteryVoltage": 2.881,
"TxPower": 4,
"MovementCounter": 184,
"MeasurementSequenceNumber": 12774,
"MacAddress": "12-34-56-78-90-AB"
}
발견 된 모든 장치의 정보 얻기 :
var adapterName = "hci0";
var scanDurationSeconds = 5;
IBleReader reader = new BleReader(new DotNetBlueZService());
await reader.ScanAsync(adapterName, scanDurationSeconds);
var deviceInfoList = await reader.GetAllDevicesAsync();
var firstDevice = deviceInfoList.FirstOrDefault();
if (firstDevice != null)
{
var bytesAsString = BitConverter.ToString(firstDevice.ManufacturerData?.Data);
Console.WriteLine($"Bluetooth device with address {firstDevice.Address} found");
Console.WriteLine($"Manufacturer ID = {firstDevice.ManufacturerData?.Id}");
Console.WriteLine($"Manufacturer data = {bytesAsString}");
}
else
{
Console.WriteLine("No devices found");
}
산출:
Bluetooth device with address 12:34:56:78:90:AB found
Manufacturer ID = 1177
Manufacturer data = 05-0E-24-2A-F6-C6-06-FF-FC-FF-F4-04-08-A0-36-B8-31-E6-12-34-56-78-90-AB
버그, 기능 요청 또는 풀 요청 (다른 장치 유형에 대한 지원 구현)을 제출하여 기여할 수 있습니다.