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:
- 34:a9648877491f
- Parent:
- 33:f87f06292637
- Child:
- 35:b8d3f1e68000
--- a/Display/LCD.cpp Mon Feb 06 12:29:33 2017 +0000
+++ b/Display/LCD.cpp Sat May 20 21:12:05 2017 +0000
@@ -290,8 +290,19 @@
// 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>>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)));}
+
+ //buffer[0]=0xFF;
+ //buffer[16]=0xAA;
+ //buffer[1023]=0xFF;
+
}
unsigned short LCD::pixelread(int x, int y)
{
