nanoFramework.Iot.Device.Ds18b20
1.0.173
Prefix Reserved
See the version list below for details.
dotnet add package nanoFramework.Iot.Device.Ds18b20 --version 1.0.173
NuGet\Install-Package nanoFramework.Iot.Device.Ds18b20 -Version 1.0.173
<PackageReference Include="nanoFramework.Iot.Device.Ds18b20" Version="1.0.173" />
paket add nanoFramework.Iot.Device.Ds18b20 --version 1.0.173
#r "nuget: nanoFramework.Iot.Device.Ds18b20, 1.0.173"
// Install nanoFramework.Iot.Device.Ds18b20 as a Cake Addin #addin nuget:?package=nanoFramework.Iot.Device.Ds18b20&version=1.0.173 // Install nanoFramework.Iot.Device.Ds18b20 as a Cake Tool #tool nuget:?package=nanoFramework.Iot.Device.Ds18b20&version=1.0.173
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.14.2)
- nanoFramework.Device.OneWire (>= 1.4.8)
- nanoFramework.System.Device.Model (>= 1.2.216)
- UnitsNet.nanoFramework.Temperature (>= 4.150.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.803 | 78 | 3/11/2025 |
1.0.797 | 76 | 3/10/2025 |
1.0.773 | 120 | 2/26/2025 |
1.0.726 | 122 | 2/4/2025 |
1.0.723 | 91 | 2/4/2025 |
1.0.706 | 98 | 1/31/2025 |
1.0.694 | 96 | 1/20/2025 |
1.0.669 | 113 | 12/30/2024 |
1.0.647 | 107 | 12/16/2024 |
1.0.624 | 134 | 10/23/2024 |
1.0.607 | 116 | 10/3/2024 |
1.0.590 | 106 | 9/6/2024 |
1.0.582 | 114 | 8/28/2024 |
1.0.564 | 143 | 8/9/2024 |
1.0.557 | 86 | 8/2/2024 |
1.0.552 | 92 | 7/26/2024 |
1.0.541 | 113 | 7/17/2024 |
1.0.524 | 124 | 6/19/2024 |
1.0.487 | 157 | 4/15/2024 |
1.0.465 | 141 | 3/22/2024 |
1.0.445 | 134 | 2/28/2024 |
1.0.425 | 159 | 1/24/2024 |
1.0.413 | 183 | 1/5/2024 |
1.0.409 | 158 | 12/20/2023 |
1.0.387 | 161 | 11/10/2023 |
1.0.367 | 128 | 11/8/2023 |
1.0.354 | 173 | 10/6/2023 |
1.0.347 | 154 | 9/27/2023 |
1.0.335 | 177 | 9/6/2023 |
1.0.329 | 189 | 8/16/2023 |
1.0.320 | 167 | 8/2/2023 |
1.0.314 | 180 | 7/28/2023 |
1.0.308 | 175 | 7/19/2023 |
1.0.305 | 160 | 7/14/2023 |
1.0.296 | 177 | 6/21/2023 |
1.0.292 | 161 | 6/14/2023 |
1.0.288 | 173 | 6/7/2023 |
1.0.286 | 187 | 6/2/2023 |
1.0.280 | 179 | 5/26/2023 |
1.0.253 | 200 | 5/10/2023 |
1.0.248 | 156 | 5/3/2023 |
1.0.224 | 304 | 3/17/2023 |
1.0.218 | 295 | 3/10/2023 |
1.0.214 | 297 | 3/8/2023 |
1.0.210 | 320 | 2/27/2023 |
1.0.207 | 289 | 2/24/2023 |
1.0.204 | 306 | 2/22/2023 |
1.0.173 | 352 | 1/9/2023 |
1.0.168 | 366 | 1/6/2023 |
1.0.159 | 347 | 1/3/2023 |
1.0.154 | 355 | 12/28/2022 |
1.0.110 | 431 | 11/14/2022 |
1.0.104 | 437 | 11/5/2022 |
1.0.38 | 549 | 9/15/2022 |
1.0.14 | 485 | 9/3/2022 |
1.0.3 | 490 | 8/17/2022 |
1.0.1 | 455 | 8/16/2022 |