2.4 TFT LCD Display + Arduino Code Fixed

by martinhui in Circuits > Arduino

4463 Views, 19 Favorites, 0 Comments

2.4 TFT LCD Display + Arduino Code Fixed

FILE0001.JPG

I'm recently experimenting the 2.4" TFT LCD Display with Arduino, I bought the LCD not intended to do something but just want to know if it work or not. I searched the instructables, youtube but a lot of code didn't work, so I proceed an intensive case study to check it why, maybe my version of board differs, I start amend the existing code and finally got a breakthrough and hopefully can highlight to those others who are facing the same problem.

The original code name called tftpaint.ino, a simple online search can easily found it, I only highlighting the changes I made here to get it work.

1. Some code have used the library of SWTFT.h cannot work on my board, I change back to Adafruit_TFTLCD.h.

2. Corrected the define pins as

#define YP A3 // must be an analog pin, use "An" notation!

#define XM A2 // must be an analog pin, use "An" notation!

#define YM 9 // can be a digital pin

#define XP 8 // can be a digital pin

3. Re-allocated the anchor point for color blocks, seeming the XY coordinates of my board is differ

tft.fillRect(BOXSIZE*5, BOXSIZE*0, BOXSIZE, BOXSIZE, RED);
tft.fillRect(BOXSIZE*4, BOXSIZE*0, BOXSIZE, BOXSIZE, YELLOW);

tft.fillRect(BOXSIZE*3, BOXSIZE*0, BOXSIZE, BOXSIZE, GREEN);

tft.fillRect(BOXSIZE*2, BOXSIZE*0, BOXSIZE, BOXSIZE, CYAN);

tft.fillRect(BOXSIZE*1, BOXSIZE*0, BOXSIZE, BOXSIZE, BLUE);

tft.fillRect(BOXSIZE*0, BOXSIZE*0, BOXSIZE, BOXSIZE, MAGENTA);

Change the Coordinates

FILE0002.JPG

4. Changed the point scale as stated

p.x = tft.width()-(map(p.x, TS_MINX, TS_MAXX, 0, tft.width()));

p.y = tft.height()-(map(p.y, TS_MINY, TS_MAXY, 0, tft.height()));

5. Amended the coordinates to display blocks and colors

if (p.x > BOXSIZE * 5) {

currentcolor = RED;

tft.drawRect(BOXSIZE * 5, BOXSIZE*0, BOXSIZE, BOXSIZE, WHITE);

} else if (p.x > BOXSIZE * 4) {

currentcolor = YELLOW;

tft.drawRect(BOXSIZE * 4, BOXSIZE*0, BOXSIZE, BOXSIZE, WHITE);

} else if (p.x > BOXSIZE * 3) {

currentcolor = GREEN;

tft.drawRect(BOXSIZE*3, BOXSIZE*0, BOXSIZE, BOXSIZE, WHITE);

} else if (p.x > BOXSIZE * 2) {

currentcolor = CYAN;

tft.drawRect(BOXSIZE*2, BOXSIZE*0, BOXSIZE, BOXSIZE, WHITE);

} else if (p.x > BOXSIZE * 1) {

currentcolor = BLUE;

tft.drawRect(BOXSIZE*1, BOXSIZE*0, BOXSIZE, BOXSIZE, WHITE);

} else if (p.x > BOXSIZE * 0) {

currentcolor = MAGENTA;

tft.drawRect(BOXSIZE * 0, BOXSIZE * 0, BOXSIZE, BOXSIZE, WHITE);

}

if (oldcolor != currentcolor) {

if (oldcolor == RED) tft.fillRect(BOXSIZE*5, BOXSIZE*0, BOXSIZE, BOXSIZE, RED);

if (oldcolor == YELLOW) tft.fillRect(BOXSIZE*4, BOXSIZE*0, BOXSIZE, BOXSIZE, YELLOW);

if (oldcolor == GREEN) tft.fillRect(BOXSIZE*3, BOXSIZE*0, BOXSIZE, BOXSIZE, GREEN);

if (oldcolor == CYAN) tft.fillRect(BOXSIZE*2, BOXSIZE*0, BOXSIZE, BOXSIZE,CYAN);

if (oldcolor == BLUE) tft.fillRect(BOXSIZE*1, BOXSIZE*0, BOXSIZE, BOXSIZE, BLUE);

if (oldcolor == MAGENTA) tft.fillRect(BOXSIZE*0, BOXSIZE*0, BOXSIZE, BOXSIZE, MAGENTA);

}

}

if (((p.y-PENRADIUS) > BOXSIZE) && ((p.y+PENRADIUS) < tft.height())) {

tft.fillCircle(p.x, p.y, PENRADIUS, currentcolor);

}

Finally Done

FILE0004

Last step to amend the clear screen code

if (p.y > TS_MAXY-30) {
Serial.println("erase"); // press the bottom of the screen to erase

tft.fillRect(0, BOXSIZE*1, tft.width(), tft.height()-BOXSIZE*1, BLACK);

}