Grove LCD Library

Grove_LCD_RGB_Backlight.h

Committer:
DavidElmoRoss
Date:
2020-12-31
Revision:
3:3946b6e87adc
Parent:
2:5ce38ef7a7db

File content as of revision 3:3946b6e87adc:

#include "mbed.h"

// I2C addresses for LCD and RGB
#define LCD_ADDRESS     (0x7c)
#define RGB_ADDRESS     (0xc4)

#define RED_REG         0x04        
#define GREEN_REG       0x03        
#define BLUE_REG        0x02        

// commands
#define LCD_CLEARDISPLAY 0x01
#define LCD_DISPLAYCONTROL 0x08
#define LCD_FUNCTIONSET 0x20

// flags for display on/off control
#define LCD_DISPLAYON 0x04
#define LCD_DISPLAYOFF 0x00

// flag for entry mode
#define LCD_ENTRYLEFT 0x02

// flags for function set
#define LCD_8BITMODE 0x10
#define LCD_2LINE 0x08
#define LCD_5x10DOTS 0x04

/** Grove_LCD_RGB_Backlight Class.
*   Used for connecting a Grove LCD RGB Backlit display
*   to an mbed microcontroller via an I2C interface.
*/    
class Grove_LCD_RGB_Backlight
{
public:
    
    /** Contructor. Creates an instance of the Grove_LCD_RGB_Backlight class.
    *   @param sda SDA pin on the mbed microcontroller which will be used to communicate with the display.
    *   @param scl SCL pin on the mbed microcontroller which will be used to communicate with the display.
    */
    Grove_LCD_RGB_Backlight(PinName sda, PinName scl); 
    

    
    /** Set RGB color of backlight
    *   @param r Value for the red component of the RGB backlight (Between 0 and 255).
    *   @param g Value for the green component of the RGB backlight (Between 0 and 255).
    *   @param b Value for the blue component of the RGB backlight (Between 0 and 255).
    */
    void setRGB(char r, char g, char b);     
    
    
    /** Removes all of the text from the display.
    */
    void clear();
    
    // This function in conjunction with hex2dec will output BCD values
    // on the LCD screen
    void write(char data1);
    
    // This function will output characters both ASCII and ALTERNATE
    void writech(char data2);
    
    /**Prints text to the LCD display.
    * @param *str Pointer to an array of characters which will be printed to the LCD screen.
    */
    void print(char *str);
    
    /**Move cursor to specified location on the LCD screen.
    * @param col Value for which column on the display the next text being printed will start at.
    * @param row Value for which row on the display the next text being printed will be printed on.
    */
    void locate(char col, char row);

    
private:
    
    //Initialize device
    void init();   
    
    //Turn on display
    void displayOn();
    
    //Send command to display
    void sendCommand(char value);
    
    //Set register value
    void setReg(char addr, char val);
    
    //MBED I2C object used to transfer data to LCD
    I2C i2c;              
    
};