Skip to content

Contains complete instructions and Java programs for connecting LCD display to I2C port.

Notifications You must be signed in to change notification settings

RaiderRobotics/FRC-LCD-Display

Repository files navigation

FRC-LCD-Display

🔷 The source code here demonstrates how to set up a 4x20 LCD panel display with the Roborio (for FRC First Robotics Competition).

All you have to do to use it is add the code that I've written, and then run the command LCDwriteString(String s, int line); where String s is the string to write to the display, and int line is line number (1-4).

p1 p2 p3


First the hardware:

▪️ We're using a display like the one in the photo

photo1.

p5

▪️ Note that it comes with a backplate thing mounted on it. This backplate already has all of the connections between the LCD display and the I2C protocol.

photo2

▪️ The connectors on the back of the LCD display do not match the connectors on the RoboRIO. The RoboRIO has the pins in a different order. Also note that the LCD display requires 5V, not the 3.3V on the RoboRIO I2C connector. We're just using 5V from a digital IO pin. You could also use the 5V from the Voltage Regulator Module.


CODE

Background information

💥 WPI Documentation The WPI documenation is completely useless. The source code is no help either.

It's easy to make an I2C object: lcdDisplay = new I2C(I2C.Port.kOnboard, 0x27); The address of most LCD panels is 0x27. It's a lot harder to write to the display since the only thing that the documentation tells you is boolean write (int registerAddress, int data). There is no explanation of what the register address should be, no examples of this being used anywhere. (I finally figured it out, see below.)

💥 LCD Panels are all driven by the Hitachi HD44780 driver. This page provides details, explains the display addressing, and lists the commands that are build in.

💥 There are some very useful code examples here:

💥 Finally, I realized that my python code 🐍 (which I got from someone else's Raspberry Pi repository) could be directly ported to Java. It worked!!!


How the code works

  • It turns out that the register to write the I2C data is ALWAYS 0 (I'm talking about the WPI I2C.write() command). Why? This is either the I2C controller or the register on the I2C device. So it seems that the LCD display only has one (external facing) register.
  • However ... internally, there are TWO registers: a command register and a data/display register. The registers are INTERNAL and are selected by using the Rs bit or not.
  • Commands are always written 4 bits at a time. Why? This is because it's the way that everyone does it. (Originally it was so that you need fewer data lines connected to your display.)
  • Commands have to be "strobed" using the En bit for them to take effect.
  • Commands do not execute instantaneously, so you need a short delay between them.
  • There is a sequence of initialization commands that must be done to set up the display after it's been powered on before it can be used.
  • Many of the other commands (cursor movement, etc.) I have not tried.

About

Contains complete instructions and Java programs for connecting LCD display to I2C port.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages