/*************************************************************************
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.
***************************************************************************/