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/
Revision 8:26757296c79d, committed 2015-02-17
- Comitter:
- Geremia
- Date:
- Tue Feb 17 17:54:14 2015 +0000
- Parent:
- 7:bb0383b91104
- Child:
- 9:1749ae993cfe
- Commit message:
- Fixed scroll for smaller area, better font spacing
Changed in this revision
--- a/Display/TFT.cpp Tue Feb 17 11:02:06 2015 +0000
+++ b/Display/TFT.cpp Tue Feb 17 17:54:14 2015 +0000
@@ -207,14 +207,14 @@
wr_cmd8(0x33);
wr_data16(topfixedareasize); //num lines of top fixed area
wr_data16(scrollareasize+scrollbugfix); //num lines of vertical scroll area, +1 for ILI9481 fix
- if((areasize+startY)>height()) bfa=0;
- else bfa = height()-(areasize+startY);
+ if((areasize+startY)>screensize_Y) bfa=0;
+ else bfa = screensize_Y-(areasize+startY);
wr_data16(bfa); //num lines of bottom fixed area
}
void TFT::scroll (int lines) // ie 1= scrollup 1, 479= scrolldown 1
{
wr_cmd8(0x37);
- wr_data16((topfixedareasize+lines)%scrollareasize); //num lines of top fixed area
+ wr_data16(topfixedareasize+(lines%scrollareasize)); // select the (absolute)line which will be displayed as first scrollarea line
}
void TFT::scrollreset()
{
--- a/Display/TFT.h Tue Feb 17 11:02:06 2015 +0000
+++ b/Display/TFT.h Tue Feb 17 17:54:14 2015 +0000
@@ -47,10 +47,10 @@
*/
virtual void window(int x, int y, int w, int h);
- /** Read pixel color at current location
+ /** Read pixel color at location
* @param x is the horizontal offset to this pixel.
* @param y is the vertical offset to this pixel.
- * @param color defines the color for the pixel.
+ * @returns 16bit color.
*/
virtual unsigned short pixelread(int x, int y);
--- a/Graphics/GraphicsDisplay.cpp Tue Feb 17 11:02:06 2015 +0000
+++ b/Graphics/GraphicsDisplay.cpp Tue Feb 17 17:54:14 2015 +0000
@@ -25,7 +25,7 @@
#include "GraphicsDisplay.h"
#define SWAP(a, b) { a ^= b; b ^= a; a ^= b; }
GraphicsDisplay::GraphicsDisplay(const char *name):TextDisplay(name) {
- set_font((unsigned char*)Terminal6x8);
+ set_font((unsigned char*)Terminal6x8,32,127,true);
// foreground(0xFFFF);
// background(0x0000);
char_x = 0;
@@ -299,8 +299,12 @@
}
}
}
- if(fontprop) char_x += w;
- else char_x += fonthor;
+ if(fontprop)
+ {
+ if((w+1)<fonthor) char_x += w+1; // put at least 1 blank after variable-width characters, except characters that occupy whole fonthor space like "_"
+ else char_x += fonthor;
+ }
+ else char_x += fonthor; // fixed width
}
void GraphicsDisplay::Bitmap_BW(Bitmap_s bm, int x, int y)
{
