UniGraphic-Fork for ST7920-LCD-controller and SH1106. Tested with 128x64 LCD with SPI and 128x64-OLED with IIC
Dependents: UniGraphic-St7920-Test AfficheurUTILECO
Fork of UniGraphic by
Fork of the UniGraphic-Library for monochrome LCDs with ST7920 controller and 128x64-IIC-OLED-Display with SH1106-Controller

Had to adapt LCD for following reasons:
- Give access to screenbuffer buffer[] to parent class
- pixel() and pixel_read() as they are hardware-dependent
- added reset-pin to IIC-Interface
GraphicDisplay:: sends buffer to LCD when auto_update is set to true.
Testprogram for ST7920 can be found here:
https://developer.mbed.org/users/charly/code/UniGraphic-St7920-Test/
Diff: Display/LCD.cpp
- Revision:
- 35:b8d3f1e68000
- Parent:
- 34:a9648877491f
- Child:
- 36:668396f861d2
--- a/Display/LCD.cpp Sat May 20 21:12:05 2017 +0000
+++ b/Display/LCD.cpp Sun May 21 20:50:09 2017 +0000
@@ -93,7 +93,6 @@
set_auto_up(true);
tftID=0;
// locate(0,0);
-
}
LCD::LCD(proto_t displayproto, int Hz, int address, PinName sda, PinName scl, const int lcdsize_x, const int lcdsize_y, const int ic_x_segs, const int ic_y_coms, const char* name)
: GraphicsDisplay(name), screensize_X(lcdsize_x), screensize_Y(lcdsize_y), _LCDPAGES(lcdsize_y>>3), _IC_X_SEGS(ic_x_segs), _IC_Y_COMS(ic_y_coms), _IC_PAGES(ic_y_coms>>3)
@@ -290,14 +289,9 @@
// first check parameter
if((x >= screensize_X) || (y >= screensize_Y)) return;
- //if(color) buffer[(x + ((y>>3)*screensize_X))^1] &= ~(1 << (y&7)); // erase pixel
- //else buffer[(x + ((y>>3)*screensize_X))^1] |= (1 << (y&7)); //Black=0000, set pixel
-
- //if(color) buffer[(x + y*16)] &= ~(1 << (7-(x&7))); // erase pixel
- //else buffer[(x + y*16)] |= (1 << (7-(x&7))); //Black=0000, set pixel
-
- if (color) {buffer[(x>>3)+(y*16)]&= ~(1 << (7-(x&7)));}
- else {buffer[(x>>3)+(y*16)]|= (1 << (7-(x&7)));}
+
+ if (color) {buffer[(x>>3)+(y*_IC_X_SEGS>>4)]&= ~(1 << (7-(x&7)));}
+ else {buffer[(x>>3)+(y*_IC_X_SEGS>>4)]|= (1 << (7-(x&7)));}
//buffer[0]=0xFF;
//buffer[16]=0xAA;
@@ -310,7 +304,8 @@
// first check parameter
if((x >= screensize_X) || (y >= screensize_Y)) return 0;
- if((buffer[(x + ((y>>3)*screensize_X))^1] & (1 << (y&7)))==0) return 0xFFFF ; // pixel not set, White
+
+ if((buffer[(x>>3)+(y*_IC_X_SEGS>>4)] & (1 << (7-(x&7))))==0) return 0xFFFF ; // pixel not set, White
else return 0; // pixel set, Black
}
void LCD::copy_to_lcd(void)
