Basically i glued Peter Drescher and Simon Ford libs in a GraphicsDisplay class, then derived TFT or LCD class (which inherits Protocols class), then the most derived ones (Inits), which are per-display and are the only part needed to be adapted to diff hw.
Dependents: afero_poc15_180216 afero_poc15_180223 afero_poc15_180302 afero_poc15_180403R ... more
Fork of UniGraphic by
UniGraphic for La Suno Version.
To go with La Suno, WatchDog Reset functions were added in ILI9341.
Diff: Inits/ILI9486.cpp
- Revision:
- 4:12ba0ecc2c1f
- Child:
- 7:bb0383b91104
diff -r 48f3282c2be8 -r 12ba0ecc2c1f Inits/ILI9486.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Inits/ILI9486.cpp Sun Feb 15 20:06:07 2015 +0000 @@ -0,0 +1,150 @@ + /* mbed UniGraphic library - Device specific class + * Copyright (c) 2015 Giuliano Dianda + * Released under the MIT License: http://mbed.org/license/mit + */ +#include "Protocols.h" +#include "ILI9486.h" + +////////////////////////////////////////////////////////////////////////////////// +// display settings /////////////////////////////////////////////////////// +///////////////////////////////////////////////////////////////////////// + +#define LCDSIZE_X 320 // display X pixels, TFTs are usually portrait view +#define LCDSIZE_Y 480 // display Y pixels + + + +ILI9486::ILI9486(proto_t displayproto, PortName port, PinName CS, PinName reset, PinName DC, PinName WR, PinName RD, const char *name) + : TFT(displayproto, port, CS, reset, DC, WR, RD, LCDSIZE_X, LCDSIZE_Y, name) +{ + hw_reset(); + BusEnable(true); + init(); + mipistd=false; + scrollbugfix=1; // when scrolling 1 line, the last line disappears, set to 1 to fix it + set_orientation(0); + cls(); + locate(0,0); +} +ILI9486::ILI9486(proto_t displayproto, int Hz, PinName mosi, PinName miso, PinName sclk, PinName CS, PinName reset, PinName DC, const char *name) + : TFT(displayproto, Hz, mosi, miso, sclk, CS, reset, DC, LCDSIZE_X, LCDSIZE_Y, name) +{ + hw_reset(); //TFT class forwards to Protocol class + BusEnable(true); //TFT class forwards to Protocol class + init(); // per display custom init cmd sequence, implemented here + mipistd=false; + scrollbugfix=1; // when scrolling 1 line, the last line disappears, set to 1 to fix it + set_orientation(0); //TFT class does for MIPI standard and some ILIxxx + cls(); + locate(0,0); +} +// reset and init the lcd controller +void ILI9486::init() +{ + /* Start Initial Sequence ----------------------------------------------------*/ + + wr_cmd8(0xF1); + wr_data8(0x36); + wr_data8(0x04); + wr_data8(0x00); + wr_data8(0x3C); + wr_data8(0x0F); + wr_data8(0x8F); + + + wr_cmd8(0xF2); + wr_data8(0x18); + wr_data8(0xA3); + wr_data8(0x12); + wr_data8(0x02); + wr_data8(0xb2); + wr_data8(0x12); + wr_data8(0xFF); + wr_data8(0x10); + wr_data8(0x00); + + wr_cmd8(0xF8); + wr_data8(0x21); + wr_data8(0x04); + + wr_cmd8(0xF9); + wr_data8(0x00); + wr_data8(0x08); + + wr_cmd8(0xC0); + wr_data8(0x0f); //13 + wr_data8(0x0f); //10 + + wr_cmd8(0xC1); + wr_data8(0x42); //43 + + wr_cmd8(0xC2); + wr_data8(0x22); + + wr_cmd8(0xC5); + wr_data8(0x01); //00 + wr_data8(0x29); //4D + wr_data8(0x80); + + wr_cmd8(0xB6); + wr_data8(0x00); + wr_data8(0x02); //42 + wr_data8(0x3b); + + wr_cmd8(0xB1); + wr_data8(0xB0); //C0 + wr_data8(0x11); + + wr_cmd8(0xB4); + wr_data8(0x02); //01 + + wr_cmd8(0xE0); + wr_data8(0x0F); + wr_data8(0x18); + wr_data8(0x15); + wr_data8(0x09); + wr_data8(0x0B); + wr_data8(0x04); + wr_data8(0x49); + wr_data8(0x64); + wr_data8(0x3D); + wr_data8(0x08); + wr_data8(0x15); + wr_data8(0x06); + wr_data8(0x12); + wr_data8(0x07); + wr_data8(0x00); + + wr_cmd8(0xE1); + wr_data8(0x0F); + wr_data8(0x38); + wr_data8(0x35); + wr_data8(0x0a); + wr_data8(0x0c); + wr_data8(0x03); + wr_data8(0x4A); + wr_data8(0x42); + wr_data8(0x36); + wr_data8(0x04); + wr_data8(0x0F); + wr_data8(0x03); + wr_data8(0x1F); + wr_data8(0x1B); + wr_data8(0x00); + + wr_cmd8(0x20); // display inversion OFF + + wr_cmd8(0x36); // MEMORY_ACCESS_CONTROL (orientation stuff) + wr_data8(0x48); + + wr_cmd8(0x3A); // COLMOD_PIXEL_FORMAT_SET + wr_data8(0x55); // 16 bit pixel + + wr_cmd8(0x13); // Nomal Displaymode + + wr_cmd8(0x11); // sleep out + wait_ms(150); + + wr_cmd8(0x29); // display on + wait_ms(150); +} \ No newline at end of file