Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Issue #6 fixed and reading functions added #32

Open
wants to merge 11 commits into
base: master
Choose a base branch
from
2 changes: 2 additions & 0 deletions keywords.txt
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ scrollDisplayLeft KEYWORD2
scrollDisplayRight KEYWORD2
createChar KEYWORD2
setRowOffsets KEYWORD2
readBFAddr KEYWORD2
readRAM KEYWORD2
per1234 marked this conversation as resolved.
Show resolved Hide resolved

#######################################
# Constants (LITERAL1)
Expand Down
70 changes: 70 additions & 0 deletions src/LiquidCrystal.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -263,15 +263,25 @@ void LiquidCrystal::noAutoscroll(void) {
// Allows us to fill the first 8 CGRAM locations
// with custom characters
void LiquidCrystal::createChar(uint8_t location, uint8_t charmap[]) {
int ramAddr = readBFAddr();
location &= 0x7; // we only have 8 locations 0-7
command(LCD_SETCGRAMADDR | (location << 3));
for (int i=0; i<8; i++) {
write(charmap[i]);
}
if(ramAddr !=-1)
command(LCD_SETDDRAMADDR | ramAddr);
}

/*********** mid level commands, for sending data/cmds */

inline int LiquidCrystal::readBFAddr(void) {
return read(LOW);
}
int LiquidCrystal::readRAM(void) {
return read(HIGH);
}

inline void LiquidCrystal::command(uint8_t value) {
send(value, LOW);
}
Expand Down Expand Up @@ -300,6 +310,35 @@ void LiquidCrystal::send(uint8_t value, uint8_t mode) {
}
}

int LiquidCrystal::read(bool mode) {
if (_rw_pin == 255) { // if there is a RW pin indicated, only then we can read
return -1;
}
else{
digitalWrite(_rw_pin, HIGH);//for read
digitalWrite(_rs_pin, mode);

for (int i=0; i<((_displayfunction & LCD_8BITMODE) ? 8 : 4); ++i)
{
pinMode(_data_pins[i], INPUT);//library initializes data pins in output mode, so we need to change mode for reading
}

uint8_t address;
if (_displayfunction & LCD_8BITMODE) {
address = read8bits();
} else {
address = read4bits();
}

for (int i=0; i<((_displayfunction & LCD_8BITMODE) ? 8 : 4); ++i)
{
pinMode(_data_pins[i], OUTPUT);
}

return int(address);
}
}

void LiquidCrystal::pulseEnable(void) {
digitalWrite(_enable_pin, LOW);
delayMicroseconds(1);
Expand All @@ -324,3 +363,34 @@ void LiquidCrystal::write8bits(uint8_t value) {

pulseEnable();
}


uint8_t LiquidCrystal::read4bits() {
uint8_t address;
digitalWrite(_enable_pin, LOW);
delayMicroseconds(1);
digitalWrite(_enable_pin, HIGH);
delayMicroseconds(1); // enable pulse must be >450ns
address = digitalRead(_data_pins[3])<<7|digitalRead(_data_pins[2])<<6|digitalRead(_data_pins[1])<<5|digitalRead(_data_pins[0])<<4;
digitalWrite(_enable_pin, LOW);
delayMicroseconds(100); // commands need > 37us to settle

digitalWrite(_enable_pin, HIGH);
delayMicroseconds(1); // enable pulse must be >450ns
address |= digitalRead(_data_pins[3])<<3|digitalRead(_data_pins[2])<<2|digitalRead(_data_pins[1])<<1|digitalRead(_data_pins[0]);
digitalWrite(_enable_pin, LOW);
delayMicroseconds(100); // commands need > 37us to settle
return address;
}

uint8_t LiquidCrystal::read8bits() {
uint8_t address;
digitalWrite(_enable_pin, LOW);
delayMicroseconds(1);
digitalWrite(_enable_pin, HIGH);
delayMicroseconds(1); // enable pulse must be >450ns
address = digitalRead(_data_pins[7])<<7|digitalRead(_data_pins[6])<<6|digitalRead(_data_pins[5])<<5|digitalRead(_data_pins[4])<<4|digitalRead(_data_pins[3])<<3|digitalRead(_data_pins[2])<<2|digitalRead(_data_pins[1])<<1|digitalRead(_data_pins[0]);
digitalWrite(_enable_pin, LOW);
delayMicroseconds(100); // commands need > 37us to settle
return address;
}
5 changes: 5 additions & 0 deletions src/LiquidCrystal.h
Original file line number Diff line number Diff line change
Expand Up @@ -82,12 +82,17 @@ class LiquidCrystal : public Print {
void setCursor(uint8_t, uint8_t);
virtual size_t write(uint8_t);
void command(uint8_t);
int readBFAddr(void);
int readRAM(void);

using Print::write;
private:
void send(uint8_t, uint8_t);
void write4bits(uint8_t);
void write8bits(uint8_t);
int read(bool);
uint8_t read4bits();
uint8_t read8bits();
void pulseEnable();

uint8_t _rs_pin; // LOW: command. HIGH: character.
Expand Down