nanoFramework.Iot.Device.Ds18b20
1.0.624
Prefix Reserved
dotnet add package nanoFramework.Iot.Device.Ds18b20 --version 1.0.624
NuGet\Install-Package nanoFramework.Iot.Device.Ds18b20 -Version 1.0.624
<PackageReference Include="nanoFramework.Iot.Device.Ds18b20" Version="1.0.624" />
paket add nanoFramework.Iot.Device.Ds18b20 --version 1.0.624
#r "nuget: nanoFramework.Iot.Device.Ds18b20, 1.0.624"
// Install nanoFramework.Iot.Device.Ds18b20 as a Cake Addin #addin nuget:?package=nanoFramework.Iot.Device.Ds18b20&version=1.0.624 // Install nanoFramework.Iot.Device.Ds18b20 as a Cake Tool #tool nuget:?package=nanoFramework.Iot.Device.Ds18b20&version=1.0.624
Ds18b20 - Temperature Sensor
The DS18B20 digital thermometer provides 9-bit to 12-bit Celsius temperature measurements and has an alarm function with nonvolatile user-programmable upper and lower trigger points.
Documentation
Product datasheet can be found here
Sensor Image
Circuit
- DATA - RX2 + TX2 shorted
- VCC - 3.3V
- GND - GND
Important: make sure you've connected data pin of sensor to two pins on the board!
Usage
Important: make sure you properly setup the Rx/Tx pins especially for ESP32 before creating the OneWireHost
, make sure you install the nanoFramework.Hardware.ESP32 nuget
:
Configuration.SetPinFunction(16, DeviceFunction.COM3_RX);
Configuration.SetPinFunction(17, DeviceFunction.COM3_TX);
Library supports three approaches to read the data from Ds18b20 sensors:
- Reading from first found sensor on OneWire bus or sensor with address passed as second parameter to the constructor:
private static void ReadingFromOneSensor()
{
OneWireHost oneWire = new OneWireHost();
Ds18b20 ds18b20 = new Ds18b20(oneWire, null, false, TemperatureResolution.VeryHigh);
ds18b20.IsAlarmSearchCommandEnabled = false;
if (ds18b20.Initialize())
{
Console.WriteLine($"Is sensor parasite powered?:{ds18b20.IsParasitePowered}");
string devAddrStr = "";
foreach (var addrByte in ds18b20.Address)
{
devAddrStr += addrByte.ToString("X2");
}
Console.WriteLine($"Sensor address:{devAddrStr}");
while (true)
{
if (!ds18b20.TryReadTemperature(out var currentTemperature))
{
Console.WriteLine("Can't read!");
}
else
{
Console.WriteLine($"Temperature: {currentTemperature.DegreesCelsius.ToString("F")}\u00B0C");
}
Thread.Sleep(5000);
}
}
oneWire.Dispose();
}
- Notification mode from first found sensor on OneWire bus or sensor with address passed as second parameter to the constructor:
private static void NotificationWhenValueHasChanged()
{
OneWireHost oneWire = new OneWireHost();
Ds18b20 ds18b20 = new Ds18b20(oneWire, null, false, TemperatureResolution.VeryHigh);
if (ds18b20.Initialize())
{
ds18b20.SensorValueChanged += (currentTemperature) =>
{
Console.WriteLine($"Temperature: {currentTemperature.DegreesCelsius.ToString("F")}\u00B0C");
};
ds18b20.BeginTrackChanges(TimeSpan.FromMilliseconds(2000));
// do whatever you want or sleep
Thread.Sleep(60000);
ds18b20.EndTrackChanges();
}
oneWire.Dispose();
}
- Using alarms - alarm is a mode when sensor has value either higher or lower than defined tresholds.
private static void UsingAlarms()
{
using OneWireHost oneWire = new OneWireHost();
Ds18b20 ds18b20 = new Ds18b20(oneWire, null, false, TemperatureResolution.VeryHigh);
if (ds18b20.Initialize())
{
for (int i = 0; i < ds18b20.AddressNet.Length; i++)
{
string devAddrStr = "";
ds18b20.Address = ds18b20.AddressNet[i];
foreach (var addrByte in ds18b20.AddressNet[i])
{
devAddrStr += addrByte.ToString("X2");
}
Console.WriteLine("18b20-" + i.ToString("X2") + " " + devAddrStr);
ds18b20.ConfigurationRead(false);
Console.WriteLine("Alarm set-points before changes:");
Console.WriteLine("Hi alarm = " + ds18b20.TemperatureHighAlarm.DegreesCelsius + " C");
Console.WriteLine("Lo alarm = " + ds18b20.TemperatureLowAlarm.DegreesCelsius + " C");
SetAlarmSetting();
}
alarmSearch();
}
else
{
Console.WriteLine("No devices found.");
}
oneWire.Dispose();
void alarmSearch()
{
int loopRead = 1000;
ds18b20.IsAlarmSearchCommandEnabled = true;
while (loopRead > 0)
{
Console.WriteLine("LoopRead " + loopRead);
if (ds18b20.SearchForAlarmCondition())
{
for (int index = 0; index < ds18b20.AddressNet.Length; index++)
{
ds18b20.Address = ds18b20.AddressNet[index];
if (ds18b20.TryReadTemperature(out var currentTemperature))
{
break;
}
string devAddrStr = "";
foreach (var addrByte in ds18b20.AddressNet[index]) devAddrStr += addrByte.ToString("X2");
Console.WriteLine("DS18B20[" + devAddrStr + "] Sensor reading in One-Shot-mode; T = " + currentTemperature.DegreesCelsius.ToString("f2") + " C");
ds18b20.ConfigurationRead(false);
Console.WriteLine("Alarm set-points:");
Console.WriteLine("Hi alarm = " + ds18b20.TemperatureHighAlarm.DegreesCelsius + " C");
Console.WriteLine("Lo alarm = " + ds18b20.TemperatureLowAlarm.DegreesCelsius + " C");
}
}
else
{
Console.WriteLine("***** No devices in alarm ****");
}
loopRead--;
}
Console.WriteLine("");
}
void SetAlarmSetting()
{
ds18b20.TemperatureHighAlarm = Temperature.FromDegreesCelsius(30);
ds18b20.TemperatureLowAlarm = Temperature.FromDegreesCelsius(25);
// Write configuration on ScratchPad.
ds18b20.ConfigurationWrite(false);
// Write configuration on EEPROM too.
ds18b20.ConfigurationWrite(true);
// Read configuration to check if changes were applied
ds18b20.ConfigurationRead(true);
Console.WriteLine("Alarm set-points after changes:");
Console.WriteLine("Hi alarm = " + ds18b20.TemperatureHighAlarm.DegreesCelsius.ToString("F") + " C");
Console.WriteLine("Lo alarm = " + ds18b20.TemperatureLowAlarm.DegreesCelsius.ToString("F") + " C");
}
}
Check samples project for more usage examples.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net is compatible. |
-
- nanoFramework.CoreLibrary (>= 1.15.5)
- nanoFramework.Device.OneWire (>= 1.4.22)
- nanoFramework.System.Device.Model (>= 1.2.670)
- UnitsNet.nanoFramework.Temperature (>= 5.60.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.624 | 80 | 10/23/2024 |
1.0.607 | 95 | 10/3/2024 |
1.0.590 | 86 | 9/6/2024 |
1.0.582 | 97 | 8/28/2024 |
1.0.564 | 118 | 8/9/2024 |
1.0.557 | 69 | 8/2/2024 |
1.0.552 | 75 | 7/26/2024 |
1.0.541 | 98 | 7/17/2024 |
1.0.524 | 108 | 6/19/2024 |
1.0.487 | 148 | 4/15/2024 |
1.0.465 | 130 | 3/22/2024 |
1.0.445 | 124 | 2/28/2024 |
1.0.425 | 145 | 1/24/2024 |
1.0.413 | 174 | 1/5/2024 |
1.0.409 | 145 | 12/20/2023 |
1.0.387 | 152 | 11/10/2023 |
1.0.367 | 113 | 11/8/2023 |
1.0.354 | 164 | 10/6/2023 |
1.0.347 | 140 | 9/27/2023 |
1.0.335 | 168 | 9/6/2023 |
1.0.329 | 179 | 8/16/2023 |
1.0.320 | 157 | 8/2/2023 |
1.0.314 | 170 | 7/28/2023 |
1.0.308 | 159 | 7/19/2023 |
1.0.305 | 150 | 7/14/2023 |
1.0.296 | 167 | 6/21/2023 |
1.0.292 | 150 | 6/14/2023 |
1.0.288 | 161 | 6/7/2023 |
1.0.286 | 174 | 6/2/2023 |
1.0.280 | 165 | 5/26/2023 |
1.0.253 | 183 | 5/10/2023 |
1.0.248 | 140 | 5/3/2023 |
1.0.224 | 291 | 3/17/2023 |
1.0.218 | 282 | 3/10/2023 |
1.0.214 | 284 | 3/8/2023 |
1.0.210 | 307 | 2/27/2023 |
1.0.207 | 275 | 2/24/2023 |
1.0.204 | 292 | 2/22/2023 |
1.0.173 | 337 | 1/9/2023 |
1.0.168 | 351 | 1/6/2023 |
1.0.159 | 323 | 1/3/2023 |
1.0.154 | 339 | 12/28/2022 |
1.0.110 | 412 | 11/14/2022 |
1.0.104 | 418 | 11/5/2022 |
1.0.38 | 531 | 9/15/2022 |
1.0.14 | 467 | 9/3/2022 |
1.0.3 | 469 | 8/17/2022 |
1.0.1 | 435 | 8/16/2022 |