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: Inits/SH1106.h
- Revision:
- 36:668396f861d2
diff -r b8d3f1e68000 -r 668396f861d2 Inits/SH1106.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Inits/SH1106.h Sun Apr 22 21:41:24 2018 +0000 @@ -0,0 +1,109 @@ +#ifndef MBED_SH1106_H +#define MBED_SH1106_H + +#include "mbed.h" +#include "LCD.h" + +/** Class for SH1106 display controller +* to be copypasted and adapted for other controllers +*/ +class SH1106 : public LCD +{ + +public: + + /** Create a PAR display interface + * @param displayproto only supports PAR_8 + * @param port GPIO port name to use + * @param CS pin connected to CS of display + * @param reset pin connected to RESET of display + * @param DC pin connected to data/command of display + * @param WR pin connected to SDI of display + * @param RD pin connected to RS of display + * @param name The name used by the parent class to access the interface + * @param LCDSIZE_X x size in pixel - optional + * @param LCDSIZE_Y y size in pixel - optional + */ + SH1106(proto_t displayproto, PortName port, PinName CS, PinName reset, PinName DC, PinName WR, PinName RD, const char* name, unsigned int LCDSIZE_X = 128, unsigned int LCDSIZE_Y = 64); + + /** Create an SPI display interface + * @param displayproto SPI_8 or SPI_16 + * @param Hz SPI speed in Hz + * @param mosi SPI pin + * @param miso SPI pin + * @param sclk SPI pin + * @param CS pin connected to CS of display + * @param reset pin connected to RESET of display + * @param DC pin connected to data/command of display + * @param name The name used by the parent class to access the interface + * @param LCDSIZE_X x size in pixel - optional + * @param LCDSIZE_Y y size in pixel - optional + */ + SH1106(proto_t displayproto, int Hz, PinName mosi, PinName miso, PinName sclk, PinName CS, PinName reset, PinName DC, const char* name , unsigned int LCDSIZE_X = 128, unsigned int LCDSIZE_Y = 64); + + /** Create an I2C display interface + * @param displayproto I2C_ + * @param Hz I2C speed in Hz + * @param address I2C address + * @param sda I2C pin + * @param scl I2C pin + * @param reset pin connected to RESET of display + * @param name The name used by the parent class to access the interface + * @param LCDSIZE_X x size in pixel - optional + * @param LCDSIZE_Y y size in pixel - optional + */ + SH1106(proto_t displayproto, int Hz, int address, PinName sda, PinName scl, PinName reset, const char* name , unsigned int LCDSIZE_X = 128, unsigned int LCDSIZE_Y = 64); + + + + /** set the contrast of the screen + * @note here overrided because of not standard value range + * @param o contrast 0-255 + */ + virtual void set_contrast(int o); + + /** set automatc horizontal scroll mode + * @param l_r direction - left = 0, right = 1 + * @param s_page start page + * @param e_page end page + * @param speed time between horizontal shift. 0 slow .. 7 fast + */ + + /** Framebuffer is used, it needs to be sent to LCD from time to time + */ + virtual void copy_to_lcd(); + + /** clear the entire screen + */ + virtual void cls(); + + /** Draw a pixel in the specified color. + * @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. + */ + virtual void pixel(int x, int y, unsigned short color); + + /** Read pixel color at location + * @param x is the horizontal offset to this pixel. + * @param y is the vertical offset to this pixel. + * @returns 16bit color, 0000=Black(pixel set), FFFF=White(pixel clear). + */ + virtual unsigned short pixelread(int x, int y); +protected: + + + /** Init command sequence + */ + void init(); + + /** set mirror mode + * @note here overriding the LCD class default one because of not standard commands + * @param mode NONE, X, Y, XY + */ + virtual void mirrorXY(mirror_t mode); + +}; + + +#endif \ No newline at end of file