Thursday, 13 September 2012

ALPHANUMERIC LCD INTERFACE WITH AT89C2051




/*************************************************************************
This software is a freeware,
                Developed By: Sarmad Tanwir
                Modified By: Khalid Nawaz Khan,
                @ VisualSoft pvt ltd, Rawalpindi, Pakistan.
                Version: 1.0.0
                Released On: 18th May, 2001
*************************************************************************

 This piece of code provides c51 functions for controlling HD44780 based LCD modules using AT9C2051 microcontroller with 8 bit interface at general purpose I/O port. Any C51 program may use these functions by just including these functions. These functions help the programmer to execute following tasks:
1. Clear or reset the display using ResetLCD function
2. Print text on the LCD using PrintLCD and PutCharLCD functions
3. Print characters or strings at user specified locations using LocateLCD function
4. Scroll the displayed text at different speeds and in different directions using ScrollLCD function
5. Shift the displayed text left or right using ShiftLCD function
6. Switch to second line of the LCD using NextLineLCD function
************************************************************************
The use of some of these functions is described below
ResetLCD function
Always used as
ResetLCD();
It resets the LCD into four bit data transfer and two line display mode, clears the LCD by writing space to all addresses and returns the cursor to the home position (i.e line 1, position 1).

PrintLCD function
Input: A null terminated (i.e. with appended \0) string in double quotes. No Return Value
Output: Prints the string on LCD starting at current cursor location
Example: PrintLCD("Welcome to VS\0");
NOTE: FOR STANDARD 'C' STRING FORMATTING USING sprintf FUNCTION BY INCLUDING 'stdio.h' IN YOUR CODE
Example:
char buffer[10];
int Integer = 10;
float Decimal = 4.43;
.
.
sprintf(buffer,"Sum = %d, Quotient = %f\0", Integer, Decimal)
PrintLCD(buffer);
Note that null termination ('\0') of the string has been catered for.

PutCharLCD function
Input: Single character in single quotes or ASCII code without quotes. No Return Value
Output: Prints the given character at current cursor location
Examples:
PutCharLCD('A');
PutCharLCD(0x41);
Both lines print the character 'A' on the lcd screen

ScrollLCD function
Inputs:
1. Direction ('r', 'l' for right and left respectively)
2. Speed (‘f’, 'm',’s’ for fast, medium and slow respectively)
3. No of repetitions (integer)
Output: Scrolls the displayed data according to the abovementioned inputs.
Example:
ScrollLCD('r','f',3);
Scrolls the contents of LCD 3 times towards right side at faster speed

LocateLCD function
Inputs:
1. Line no. (1 or 2)
2. Position (1 to 40 while only 1-16 are visible. Rest must be scrolled for viewing)
Output:
Takes the cursor to the specified location
Examples:
LocateLCD (1, 5);
PutCharLCD ('u');
Prints the character ‘u’ at line 1 position 5. Whereas
LocateLCD (2, 3);
PrintLCD("VS\0");
Prints 'VS' starting from position 3 on line 2

NextLineLCD function
Always used as
NextLineLCD();
Shifts from line 1 to line 2

ShiftLCD function
Input: Direction ('r' for right, 'l' for left)
Shifts the entire text once in the specified direction
***************************************************************************

Suggestions for further development:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

A controlled 'Highlighting' function is needed for such application as highlighting selected text on the LCD.
A 'Vertical Scroll' function for paragraph display may also be developed
It is requested that any further improvements in this software should be brought to the notice of the developer before the release of a newer version is considered.
Instructions for Distribution
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Distribution of LCD manufacturer's application notes and data sheets along with this C51 function library is recommended as it will greatly benefit the user.
***************************************************************************/