// vi:ts=4 // ---------------------------------------------------------------------------- // Serial2LCD - simple demonstration printing characters from serial port // Created by Bill Perry 2020-06-28 // bperrybap@opensource.billsworld.billandterrie.com // // This example code is unlicensed and is released into the public domain // ---------------------------------------------------------------------------- // // This sketch is for LCDs with PCF8574 or MCP23008 chip based backpacks // // Sketch demonstrates hd44780 how to read a message of characters from // serial port and display it on the LCD. // It takes advantage of the hd44780 library automatic line // wrapping capability. // See the LineWrap sketch for details about line wrapping. // // WARNING: // Use caution when using 3v only processors like arm and ESP8266 processors // when interfacing with 5v modules as not doing proper level shifting or // incorrectly hooking things up can damage the processor. // // Configure LCD_COLS, LCD_ROWS and BAUDRATE if desired/needed // Expected behavior of the sketch: // - characters received from serial port are displayed on LCD // - CR and LF are ignored/dropped // // If initialization of the LCD fails and the arduino supports a built in LED, // the sketch will simply blink the built in LED with the initalization error // code. // // NOTE: // If the sketch fails to produce the expected results, or blinks the LED, // run the included I2CexpDiag sketch to test the i2c signals and the LCD. // // Some 16x1 displays are actually a 8x2 display that have both lines on // a single line on the display. // If you have one of these displays, simply set the geometry to 8x2 instead // of 16x1. // include the needed headers. #include #include // main hd44780 header #include // i2c expander i/o class header hd44780_I2Cexp lcd; // declare lcd object: auto locate & config exapander chip // LCD geometry // while 16x2 will work on most displays even if the geometry is different, // for actual wrap testing of a particular LCD it is best to use the correct // geometry. const int LCD_COLS = 16; const int LCD_ROWS = 2; const int BAUDRATE = 9600; void setup() { int status; // initalize Serial port Serial.begin(BAUDRATE); // initialize LCD with number of columns and rows: // hd44780 returns a status from begin() that can be used // to determine if initalization failed. // the actual status codes are defined in status = lcd.begin(LCD_COLS, LCD_ROWS); if(status) // non zero status means it was unsuccesful { // begin() failed Serial.print("LCD initalization failed: "); Serial.println(status); // blink error code using the onboard LED if possible hd44780::fatalError(status); // does not return } // turn on automatic line wrapping // which automatically wraps lines to the next lower line and wraps back // to the top when at the bottom line // NOTE: // noLineWrap() can be used to disable automatic line wrapping. // _write() can be called instead of write() to send data bytes // to the display bypassing any special character or line wrap processing. lcd.lineWrap(); lcd.print("Serial2LCD"); if(LCD_ROWS > 1) { lcd.setCursor(0,1); lcd.print("Baud:"); lcd.print(BAUDRATE); } } void loop() { // check to see if characters available // indicating a message is coming in if (Serial.available()) { // wait some time for rest of message to arrive delay(100); // Clear the display before showing the new message lcd.clear(); // print the message on the LCD while (Serial.available() > 0) { char c; c = Serial.read(); if(c != '\r' && c != '\n') // drop CR and LF characters lcd.write(c); } } }