title | description | author | ms.author | ms.date | ms.topic |
---|---|---|---|---|---|
Display text on an LCD |
Learn how to display characters on a liquid crystal display with the .NET IoT Libraries. |
camsoper |
casoper |
12/05/2022 |
tutorial |
LCD character displays are useful for displaying information without the need for an external monitor. Common LCD character displays can be connected directly to the GPIO pins, but such an approach requires the use of up to 10 GPIO pins. For scenarios that require connecting to a combination of devices, devoting so much of the GPIO header to a character display is often impractical.
Many manufacturers sell 20x4 LCD character displays with an integrated GPIO expander. The character display connects directly to the GPIO expander, which then connects to the Raspberry Pi via the Inter-Integrated Circuit (I2C) serial protocol.
In this topic, you will use .NET to display text on an LCD character display using an I2C GPIO expander.
- [!INCLUDE prereq-sbc]
- 20x4 LCD Character Display with I2C interface
- Jumper wires
- Breadboard (optional/recommended)
- Raspberry Pi GPIO breakout board (optional/recommended)
- [!INCLUDE tutorial-prereq-dotnet]
[!INCLUDE rpi-note]
Note
There are many manufacturers of LCD character displays. Most designs are identical, and the manufacturer shouldn't make any difference to the functionality. For reference, this tutorial was developed with the SunFounder LCD2004.
[!INCLUDE prepare-pi-i2c]
Use jumper wires to connect the four pins on the I2C GPIO expander to the Raspberry Pi as follows:
- GND to ground
- VCC to 5V
- SDA to SDA (GPIO 2)
- SCL to SCL (GPIO 3)
Refer to the following figures as needed:
I2C interface (back of display) | Raspberry Pi GPIO |
---|---|
:::image type="content" source="../media/character-display-i2c-thumb.png" alt-text="An image of the back of the character display showing the I2C GPIO expander." lightbox="../media/character-display-i2c.png"::: | :::image type="content" source="../media/gpio-pinout-diagram-thumb.png" alt-text="A diagram showing the pinout of the Raspberry Pi GPIO header. Image courtesy Raspberry Pi Foundation." lightbox="../media/gpio-pinout-diagram.png"::: Image courtesy Raspberry Pi Foundation. |
[!INCLUDE gpio-breakout]
Complete the following steps in your preferred development environment:
-
Create a new .NET Console App using either the .NET CLI or Visual Studio. Name it LcdTutorial.
dotnet new console -o LcdTutorial cd LcdTutorial
-
[!INCLUDE tutorial-add-packages]
-
Replace the contents of Program.cs with the following code:
:::code language="csharp" source="~/iot-samples/tutorials/LcdTutorial/Program.cs" :::
In the preceding code:
-
A using declaration creates an instance of
I2cDevice
by callingI2cDevice.Create
and passing in a newI2cConnectionSettings
with thebusId
anddeviceAddress
parameters. ThisI2cDevice
represents the I2C bus. Theusing
declaration ensures the object is disposed and hardware resources are released properly.[!WARNING] The device address for the GPIO expander depends on the chip used by the manufacturer. GPIO expanders equipped with a PCF8574 use the address
0x27
, while those using PCF8574A chips use0x3F
. Consult your LCD's documentation. -
Another
using
declaration creates an instance ofPcf8574
and passes theI2cDevice
into the constructor. This instance represents the GPIO expander. -
Another
using
declaration creates an instance ofLcd2004
to represent the display. Several parameters are passed to the constructor describing the settings to use to communicate with the GPIO expander. The GPIO expander is passed as thecontroller
parameter. -
A
while
loop runs indefinitely. Each iteration:- Clears the display.
- Sets the cursor position to the first position on the current line.
- Writes the current time to the display at the current cursor position.
- Iterates the current line counter.
- Sleeps 1000 ms.
-
-
[!INCLUDE tutorial-build]
-
[!INCLUDE tutorial-deploy]
-
Run the app on the Raspberry Pi by switching to the deployment directory and running the executable.
./LcdTutorial
Observe the LCD character display as the current time displays on each line.
[!TIP] If the display is lit but you don't see any text, try adjusting the contrast dial on the back of the display.
-
Terminate the program by pressing Ctrl+C.
Congratulations! You've displayed text on an LCD using a I2C and a GPIO expander!
The source for this tutorial is available on GitHub.
[!div class="nextstepaction"] Learn to use General Purpose Input/Output to blink an LED