remove row sr update when clearing

This commit is contained in:
interfisch 2023-02-11 17:18:50 +01:00
parent fa29d3af04
commit 5b344a6b4e
3 changed files with 15 additions and 18 deletions

View file

@ -67,8 +67,9 @@ public:
void setRow(uint16_t _row);
uint16_t getRow();
void shiftData();
void shiftDataRow();
void shiftDataColumn();
};
#endif

View file

@ -70,10 +70,10 @@ void Flipdot::selectColumn(uint8_t selcolumn, bool clear) {
}
bool Flipdot::clearSelectedColumn() {
shiftDataColumn();
//Clear Columns
if (row!=0) {
return 0; //error. row is selected (short circuit!)
}
for (uint8_t cc=0;cc<COLUMNBYTES;cc++) {
//Serial.print("checking cc="); Serial.println(cc);
for (uint8_t i=0;i<8;i+=2) {
@ -96,6 +96,9 @@ bool Flipdot::clearSelectedColumn() {
}
bool Flipdot::setSelectedDot() {
shiftDataRow();
shiftDataColumn();
for (uint8_t cc=0;cc<COLUMNBYTES;cc++) {
//Serial.print("checking cc="); Serial.println(cc);
@ -112,7 +115,7 @@ bool Flipdot::setSelectedDot() {
return 0;
}
digitalWrite(PIN_SR_OE, LOW); //Active Low
digitalWrite(PIN_SR_OE, LOW); //Active Low. Enable Row
digitalWrite(PIN_DRIVE, HIGH);
delayMicroseconds(MICROS_DRIVEDOTSET); //Drive Dot
digitalWrite(PIN_SR_OE, HIGH); //Active Low
@ -137,7 +140,7 @@ bool Flipdot::HBridgeOK() {
}
void Flipdot::shiftData() { //send out all data to shift registers
void Flipdot::shiftDataRow() { //send out all data to shift registers
//select Rows via shift registers on own controller board
shiftOutSlow(PIN_SR_DATA, PIN_SR_CLK, LSBFIRST, row&0xff); //lower byte
@ -146,6 +149,10 @@ void Flipdot::shiftData() { //send out all data to shift registers
delayMicroseconds(MICROS_SHIFT_LATCH);
digitalWrite(PIN_SR_LATCH, LOW);
}
void Flipdot::shiftDataColumn() { //send out all data to shift registers
digitalWrite(PIN_RESET_DRVBRD,LOW); //get driverboard shift registers out of reset
//Select Columns via Shift registers

View file

@ -75,7 +75,6 @@ bool Image::updateByColumn(bool direction, bool clearFirst, bool optimizeClear,
if (update_counter%2==0) { //even counter numbers are for clearing
flipdot.setRow(0);
flipdot.selectColumnClear(x);
flipdot.shiftData();
if (!flipdot.clearSelectedColumn()) {
Serial.println("Error clearing column!");
}
@ -84,7 +83,6 @@ bool Image::updateByColumn(bool direction, bool clearFirst, bool optimizeClear,
flipdot.selectColumnSet(x); //lower column number is on the left
flipdot.setRow(backBuffer[x]);
flipdot.shiftData();
flipdot.setSelectedDot();
frontBuffer[x]=backBuffer[x]; //flip current column in buffer
@ -114,7 +112,6 @@ void Image::loop_testDots() {
for (int l=0;l<COLUMNS;l++) {
flipdot.selectColumnClear(l%COLUMNS);
flipdot.shiftData();
if (!flipdot.clearSelectedColumn()) {
Serial.println("Error clearing column!");
@ -135,7 +132,6 @@ void Image::loop_testDots() {
Serial.println("Clearing");
flipdot.setRow(0);
flipdot.selectColumnClear(23);
flipdot.shiftData();
if (!flipdot.clearSelectedColumn()) {
Serial.println("Error clearing column!");
}
@ -143,7 +139,6 @@ void Image::loop_testDots() {
flipdot.setRow(0);
flipdot.selectColumnClear(24);
flipdot.shiftData();
if (!flipdot.clearSelectedColumn()) {
Serial.println("Error clearing column!");
}
@ -157,7 +152,6 @@ void Image::loop_testDots() {
flipdot.setRow(0);
flipdot.setRow(flipdot.getRow()+pow(2, 4));//low significant bits are lower rows (when connector at top)
flipdot.setRow(flipdot.getRow()+pow(2, 5));//low significant bits are lower rows (when connector at top)
flipdot.shiftData();
flipdot.setSelectedDot();
delay(50);
}
@ -180,8 +174,6 @@ void Image::loop_drawClearTest() {
for (int l=0;l<COLUMNS;l++) {
flipdot.selectColumnClear(l%COLUMNS);
flipdot.shiftData();
if (!flipdot.clearSelectedColumn()) {
Serial.println("Error clearing column!");
}else{
@ -222,9 +214,6 @@ void Image::loop_drawClearTest() {
//reset pin on ribbon cable high (12Vpullup/open), then low (via Transistor)
unsigned long starttime=micros();
flipdot.shiftData();
flipdot.setSelectedDot();