![]() |
VOOZH | about |
dotnet add package nanoFramework.Iot.Device.Sn74hc595 --version 1.2.907
NuGet\Install-Package nanoFramework.Iot.Device.Sn74hc595 -Version 1.2.907
<PackageReference Include="nanoFramework.Iot.Device.Sn74hc595" Version="1.2.907" />
<PackageVersion Include="nanoFramework.Iot.Device.Sn74hc595" Version="1.2.907" />Directory.Packages.props
<PackageReference Include="nanoFramework.Iot.Device.Sn74hc595" />Project file
paket add nanoFramework.Iot.Device.Sn74hc595 --version 1.2.907
#r "nuget: nanoFramework.Iot.Device.Sn74hc595, 1.2.907"
#:package nanoFramework.Iot.Device.Sn74hc595@1.2.907
#addin nuget:?package=nanoFramework.Iot.Device.Sn74hc595&version=1.2.907Install as a Cake Addin
#tool nuget:?package=nanoFramework.Iot.Device.Sn74hc595&version=1.2.907Install as a Cake Tool
SN74HC595 is a 8-bit shift register. Per the datasheet, the SN74HC595 is a "8-Bit Shift Register With 3-State Output Register". The is based on and is compatible with the more general binding. The Sn74hc595 binding adds the ability clear the storage register with a single pin. Either binding can be used to control the SN74HC595.
The abstracts the interaction with the data register, the register clock and other shift register capabilities. The binding enables interaction via GPIO or SPI.
The following example code demonstrates how to use the SN74HC595 with its most basic functions.
Sn74hc595 sr = new(Sn74hc595PinMapping.Minimal);
// Light up three of first four LEDs
sr.ShiftBit(1);
sr.ShiftBit(1);
sr.ShiftBit(0);
sr.ShiftBit(1);
sr.Latch();
// Display for 1s
Thread.Sleep(1000);
// Write to all 8 registers with a byte value
// ShiftByte latches data by default
sr.ShiftByte(0b_1000_1101);
The following diagram demonstrates the required wiring for the Minimal pin mapping. In particular, OE must be wired to ground, and SRCLR must be wired high.
The following example demonstrates using additional features and requires different wiring.
Sn74hc595 sr = new(Sn74hc595PinMapping.Complete);
// Write to all 8 registers with a byte value
// ShiftByte latches data by default
sr.ShiftByte(0b_1000_1101);
// Display for 1s
Thread.Sleep(1000);
// disable output temporarily
sr.OutputEnable = false;
// Display for 1s
Thread.Sleep(1000);
// re-enable output
sr.OutputEnable = true;
// clear storage before writing new values
sr.ClearStorage();
// Light up three of first four LEDs
sr.ShiftBit(1);
sr.ShiftBit(1);
sr.ShiftBit(0);
sr.ShiftBit(1);
sr.Latch();
The following diagram demonstrates the required wiring for the Complete pin mapping.
If you want to use SPI, see the binding, which includes more information on SPI.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET Framework | net net is compatible. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.0.0-preview.85 | 47 | 6/1/2026 |
| 2.0.0-preview.80 | 52 | 5/27/2026 |
| 2.0.0-preview.73 | 52 | 5/20/2026 |
| 2.0.0-preview.69 | 56 | 5/18/2026 |
| 2.0.0-preview.62 | 59 | 5/13/2026 |
| 2.0.0-preview.49 | 48 | 5/4/2026 |
| 2.0.0-preview.45 | 57 | 4/29/2026 |
| 2.0.0-preview.37 | 53 | 4/22/2026 |
| 2.0.0-preview.32 | 62 | 4/20/2026 |
| 2.0.0-preview.16 | 78 | 3/10/2026 |
| 1.2.907 | 287 | 10/2/2025 |
| 1.2.869 | 330 | 4/2/2025 |
| 1.2.864 | 303 | 4/2/2025 |
| 1.2.852 | 326 | 3/11/2025 |
| 1.2.835 | 279 | 2/27/2025 |
| 1.2.833 | 262 | 2/27/2025 |
| 1.2.829 | 260 | 2/27/2025 |
| 1.2.822 | 262 | 2/26/2025 |
| 1.2.775 | 269 | 2/4/2025 |
| 1.2.772 | 246 | 2/4/2025 |