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
diff -r f87f06292637 -r a9648877491f Display/LCD.cpp --- 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) {