Lcd Library

The mikroC PRO for ARM provides a library for communication with Lcds (with HD44780 compliant controllers) through the 4-bit interface.

For creating a set of custom Lcd characters use Lcd Custom Character Tool.

Library Dependency Tree

Lcd Library Dependency Tree

External dependencies of Lcd Library

Stellaris

The following variables must be defined in all projects using Lcd Library : Description : Example :
extern sfr sbit LCD_RS: Register Select line. sbit LCD_RS at GPIO_PORTA_DATA.B2;
extern sfr sbit LCD_EN: Enable line. sbit LCD_EN at GPIO_PORTA_DATA.B3;
extern sfr sbit LCD_D4; Data 4 line. sbit LCD_D4 at GPIO_PORTA_DATA.B4;
extern sfr sbit LCD_D5; Data 5 line. sbit LCD_D5 at GPIO_PORTA_DATA.B5;
extern sfr sbit LCD_D6; Data 6 line. sbit LCD_D6 at GPIO_PORTA_DATA.B6;
extern sfr sbit LCD_D7; Data 7 line. sbit LCD_D7 at GPIO_PORTA_DATA.B7
extern sfr sbit LCD_RS_Direction; Register Select direction pin. sbit LCD_RS_Direction at GPIO_PORTA_DIR.B2;
extern sfr sbit LCD_EN_Direction; Enable direction pin. sbit LCD_EN_Direction at GPIO_PORTA_DIR.B3;
extern sfr sbit LCD_D4_Direction; Data 4 direction pin. sbit LCD_D4_Direction at GPIO_PORTA_DIR.B4;
extern sfr sbit LCD_D5_Direction; Data 5 direction pin. sbit LCD_D5_Direction at GPIO_PORTA_DIR.B5;
extern sfr sbit LCD_D6_Direction; Data 6 direction pin. sbit LCD_D6_Direction at GPIO_PORTA_DIR.B6;
extern sfr sbit LCD_D7_Direction; Data 7 direction pin. sbit LCD_D7_Direction at GPIO_PORTA_DIR.B7;

MSP432

The following variables must be defined in all projects using Lcd Library : Description : Example :
extern sfr sbit LCD_RS: Register Select line. sbit LCD_RS at DIO_P6OUT.B2;
extern sfr sbit LCD_EN: Enable line. sbit LCD_EN at DIO_P6OUT.B3;
extern sfr sbit LCD_D4; Data 4 line. sbit LCD_D4 at DIO_P6OUT.B4;
extern sfr sbit LCD_D5; Data 5 line. sbit LCD_D5 at DIO_P6OUT.B5;
extern sfr sbit LCD_D6; Data 6 line. sbit LCD_D6 at DIO_P6OUT.B6;
extern sfr sbit LCD_D7; Data 7 line. sbit LCD_D7 at DIO_P6OUT.B7
extern sfr sbit LCD_RS_Direction; Register Select direction pin. sbit LCD_RS_Direction at DIO_P6DIR.B2;
extern sfr sbit LCD_EN_Direction; Enable direction pin. sbit LCD_EN_Direction at DIO_P6DIR.B3;
extern sfr sbit LCD_D4_Direction; Data 4 direction pin. sbit LCD_D4_Direction at DIO_P6DIR.B4;
extern sfr sbit LCD_D5_Direction; Data 5 direction pin. sbit LCD_D5_Direction at DIO_P6DIR.B5;
extern sfr sbit LCD_D6_Direction; Data 6 direction pin. sbit LCD_D6_Direction at DIO_P6DIR.B6;
extern sfr sbit LCD_D7_Direction; Data 7 direction pin. sbit LCD_D7_Direction at DIO_P6DIR.B7;

STM32

The following variables must be defined in all projects using Lcd Library : Description : Example :
extern sfr sbit LCD_RS: Register Select line. sbit LCD_RS at GPIOD_ODR.B2;
extern sfr sbit LCD_EN: Enable line. sbit LCD_EN at GPIOD_ODR.B3;
extern sfr sbit LCD_D4; Data 4 line. sbit LCD_D4 at GPIOD_ODR.B4;
extern sfr sbit LCD_D5; Data 5 line. sbit LCD_D5 at GPIOD_ODR.B5;
extern sfr sbit LCD_D6; Data 6 line. sbit LCD_D6 at GPIOD_ODR.B6;
extern sfr sbit LCD_D7; Data 7 line. sbit LCD_D7 at GPIOD_ODR.B7

CEC1x02

The following variables must be defined in all projects using Lcd Library : Description : Example :
extern sfr sbit LCD_RS: Register Select line. sbit LCD_RS at GPIO_OUTPUT0.B2;
extern sfr sbit LCD_EN: Enable line. sbit LCD_EN at GPIO_OUTPUT0.B3;
extern sfr sbit LCD_D4; Data 4 line. sbit LCD_D4 at GPIO_OUTPUT0.B4;
extern sfr sbit LCD_D5; Data 5 line. sbit LCD_D5 at GPIO_OUTPUT0.B5;
extern sfr sbit LCD_D6; Data 6 line. sbit LCD_D6 at GPIO_OUTPUT0.B6;
extern sfr sbit LCD_D7; Data 7 line. sbit LCD_D7 at GPIO_OUTPUT0.B7

Library Routines

Lcd_Init

Prototype

void Lcd_Init();

Description

Initializes Lcd module.

Parameters

None.

Returns

Nothing.

Requires

External dependencies of the library from the top of the page must be defined before using this function.

Example

Stellaris

// LCD module connections
sbit LCD_RS at GPIO_PORTA_DATA.B2;
sbit LCD_EN at GPIO_PORTA_DATA.B3;
sbit LCD_D4 at GPIO_PORTA_DATA.B4;
sbit LCD_D5 at GPIO_PORTA_DATA.B5;
sbit LCD_D6 at GPIO_PORTA_DATA.B6;
sbit LCD_D7 at GPIO_PORTA_DATA.B7;

sbit LCD_RS_Direction at GPIO_PORTA_DIR.B2;
sbit LCD_EN_Direction at GPIO_PORTA_DIR.B3;
sbit LCD_D4_Direction at GPIO_PORTA_DIR.B4;
sbit LCD_D5_Direction at GPIO_PORTA_DIR.B5;
sbit LCD_D6_Direction at GPIO_PORTA_DIR.B6;
sbit LCD_D7_Direction at GPIO_PORTA_DIR.B7;
// End LCD module connections
...
Lcd_Init();

MSP432

// LCD module connections
sbit LCD_RS at DIO_P6OUT.B2;
sbit LCD_EN at DIO_P6OUT.B3;
sbit LCD_D4 at DIO_P6OUT.B4;
sbit LCD_D5 at DIO_P6OUT.B5;
sbit LCD_D6 at DIO_P6OUT.B6;
sbit LCD_D7 at DIO_P6OUT.B7;

sbit LCD_RS_Direction at DIO_P6DIR.B2;
sbit LCD_EN_Direction at DIO_P6DIR.B3;
sbit LCD_D4_Direction at DIO_P6DIR.B4;
sbit LCD_D5_Direction at DIO_P6DIR.B5;
sbit LCD_D6_Direction at DIO_P6DIR.B6;
sbit LCD_D7_Direction at DIO_P6DIR.B7;
// End LCD module connections
...
Lcd_Init();

STM32

// LCD module connections
sbit LCD_RS at GPIOD_ODR.B2;
sbit LCD_EN at GPIOD_ODR.B3;
sbit LCD_D4 at GPIOD_ODR.B4;
sbit LCD_D5 at GPIOD_ODR.B5;
sbit LCD_D6 at GPIOD_ODR.B6;
sbit LCD_D7 at GPIOD_ODR.B7;
// End LCD module connections
...
Lcd_Init();

CEC1x02

// LCD module connections
sbit LCD_RS at GPIO_OUTPUT0.B2;
sbit LCD_EN at GPIO_OUTPUT0.B3;
sbit LCD_D4 at GPIO_OUTPUT0.B4;
sbit LCD_D5 at GPIO_OUTPUT0.B5;
sbit LCD_D6 at GPIO_OUTPUT0.B6;
sbit LCD_D7 at GPIO_OUTPUT0.B7;
// End LCD module connections
...

Lcd_Init();
Notes

None.

Lcd_Out

Prototype

void Lcd_Out(unsigned int row, unsigned int column, char *text);

Description

Prints text on Lcd starting from specified position. Both string variables and literals can be passed as a text.

Parameters
  • row: starting position row number
  • column: starting position column number
  • text: text to be written
Returns

Nothing.

Requires

The Lcd module needs to be initialized. See Lcd_Init routine.

Example
// Write text "Hello!" on Lcd starting from row 1, column 3:
Lcd_Out(1, 3, "Hello!");
Notes

None.

Lcd_Out_Cp

Prototype

void Lcd_Out_Cp(char *text);

Returns

Nothing.

Description

Prints text on Lcd at current cursor position. Both string variables and literals can be passed as a text.

Parameters
  • text: text to be written
Requires

The Lcd module needs to be initialized. See Lcd_Init routine.

Example
// Write text "Here!" at current cursor position:
Lcd_Out_Cp("Here!");
Notes

None.

Lcd_Chr

Prototype

void Lcd_Chr(unsigned int row, unsigned int column, char out_char);

Description

Prints character on Lcd at specified position. Both variables and literals can be passed as a character.

Parameters
  • row: writing position row number
  • column: writing position column number
  • out_char: character to be written
Returns

Nothing.

Requires

The Lcd module needs to be initialized. See Lcd_Init routine.

Example
// Write character "i" at row 2, column 3:
Lcd_Chr(2, 3, 'i');
Notes

None.

Lcd_Chr_Cp

Prototype

void Lcd_Chr_Cp(char out_char);

Description

Prints character on Lcd at current cursor position. Both variables and literals can be passed as a character.

Parameters
  • out_char: character to be written
Returns

Nothing.

Requires

The Lcd module needs to be initialized. See Lcd_Init routine.

Example
// Write character "e" at current cursor position:
Lcd_Chr_Cp('e');
Notes

None.

Lcd_Cmd

Prototype

void Lcd_Cmd(char out_char);

Description

Sends command to Lcd.

Parameters
  • out_char: command to be sent
Returns

Nothing.

Requires

The Lcd module needs to be initialized. See Lcd_Init table.

Example
// Clear Lcd display:
Lcd_Cmd(_LCD_CLEAR);
Notes

Predefined constants can be passed to the function, see Available Lcd Commands.

Available Lcd Commands

Lcd Command Purpose
_LCD_FIRST_ROW Move cursor to the 1st row
_LCD_SECOND_ROW Move cursor to the 2nd row
_LCD_THIRD_ROW Move cursor to the 3rd row
_LCD_FOURTH_ROW Move cursor to the 4th row
_LCD_CLEAR Clear display
_LCD_RETURN_HOME Return cursor to home position, returns a shifted display to its original position. Display data RAM is unaffected.
_LCD_CURSOR_OFF Turn off cursor
_LCD_UNDERLINE_ON Underline cursor on
_LCD_BLINK_CURSOR_ON Blink cursor on
_LCD_MOVE_CURSOR_LEFT Move cursor left without changing display data RAM
_LCD_MOVE_CURSOR_RIGHT Move cursor right without changing display data RAM
_LCD_TURN_ON Turn Lcd display on
_LCD_TURN_OFF Turn Lcd display off
_LCD_SHIFT_LEFT Shift display left without changing display data RAM
_LCD_SHIFT_RIGHT Shift display right without changing display data RAM
Copyright (c) 2002-2019 mikroElektronika. All rights reserved.
What do you think about this topic ? Send us feedback!
Want more examples and libraries? 
Find them on LibStock - A place for the code