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 GraphicsDisplay

UniGraphic for La Suno Version.
To go with La Suno, WatchDog Reset functions were added in ILI9341.

Revision:
3:48f3282c2be8
Parent:
2:713844a55c4e
Child:
4:12ba0ecc2c1f
--- a/Display/TFT.cpp	Fri Feb 13 23:17:55 2015 +0000
+++ b/Display/TFT.cpp	Sat Feb 14 17:42:21 2015 +0000
@@ -1,3 +1,15 @@
+/* mbed library for 240*320 pixel display TFT based on ILI9341 LCD Controller
+ * Copyright (c) 2013 Peter Drescher - DC2PD
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+
 #include "TFT.h"
 
 //#include "mbed_debug.h"
@@ -87,25 +99,25 @@
     switch (orientation) {
         case 0:// default, portrait view 0°
             if(mipistd) wr_data8(0x0A); // this is in real a vertical flip enabled, seems most displays are vertical flipped
-            else wr_data8(0x48); //48 for 9341
+            else wr_data8(0x48); //for some other ILIxxxx
             set_width(LCDSIZE_X);
             set_height(LCDSIZE_Y);
             break;
         case 1:// landscape view +90°
             if(mipistd) wr_data8(0x28); 
-            else wr_data8(0x29);//28 for 9341
+            else wr_data8(0x29);//for some other ILIxxxx
             set_width(LCDSIZE_Y);
             set_height(LCDSIZE_X);
             break;
         case 2:// portrait view +180°
             if(mipistd) wr_data8(0x09); 
-            else wr_data8(0x99);//88 for 9341
+            else wr_data8(0x99);//for some other ILIxxxx
             set_width(LCDSIZE_X);
             set_height(LCDSIZE_Y);
             break;
         case 3:// landscape view -90°
             if(mipistd) wr_data8(0x2B); 
-            else wr_data8(0xF8);//E8 for 9341
+            else wr_data8(0xF8);//for some other ILIxxxx
             set_width(LCDSIZE_Y);
             set_height(LCDSIZE_X);
             break;
@@ -116,6 +128,7 @@
 {
     //ili9486 does not like truncated 2A/2B cmds, at least in par mode
     //setting only start column/page would speedup, but needs a windowmax() before, maybe implement later
+    //fixme for PAR_16: // cmd 2A/2B expects 8bit parameters
     wr_cmd8(0x2A);
     wr_data16(x);   //start column
     wr_data16(x+w-1);//end column