Lorenz limit cycle - 2D nonlinear attractor

Dependencies:   mbed

Committer:
JLS
Date:
Tue Feb 08 21:43:36 2011 +0000
Revision:
0:337717573fe7

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
JLS 0:337717573fe7 1 //
JLS 0:337717573fe7 2 // TFT_4DGL is a class to drive 4D Systems TFT touch screens
JLS 0:337717573fe7 3 //
JLS 0:337717573fe7 4 // Copyright (C) <2010> Stephane ROCHON <stephane.rochon at free.fr>
JLS 0:337717573fe7 5 //
JLS 0:337717573fe7 6 // TFT_4DGL is free software: you can redistribute it and/or modify
JLS 0:337717573fe7 7 // it under the terms of the GNU General Public License as published by
JLS 0:337717573fe7 8 // the Free Software Foundation, either version 3 of the License, or
JLS 0:337717573fe7 9 // (at your option) any later version.
JLS 0:337717573fe7 10 //
JLS 0:337717573fe7 11 // TFT_4DGL is distributed in the hope that it will be useful,
JLS 0:337717573fe7 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
JLS 0:337717573fe7 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
JLS 0:337717573fe7 14 // GNU General Public License for more details.
JLS 0:337717573fe7 15 //
JLS 0:337717573fe7 16 // You should have received a copy of the GNU General Public License
JLS 0:337717573fe7 17 // along with TFT_4DGL. If not, see <http://www.gnu.org/licenses/>.
JLS 0:337717573fe7 18
JLS 0:337717573fe7 19 #include "mbed.h"
JLS 0:337717573fe7 20 #include "TFT_4DGL.h"
JLS 0:337717573fe7 21
JLS 0:337717573fe7 22
JLS 0:337717573fe7 23 //****************************************************************************************************
JLS 0:337717573fe7 24 void TFT_4DGL :: circle(int x, int y , int radius, int color) { // draw a circle in (x,y)
JLS 0:337717573fe7 25 char command[9]= "";
JLS 0:337717573fe7 26
JLS 0:337717573fe7 27 command[0] = CIRCLE;
JLS 0:337717573fe7 28
JLS 0:337717573fe7 29 command[1] = (x >> 8) & 0xFF;
JLS 0:337717573fe7 30 command[2] = x & 0xFF;
JLS 0:337717573fe7 31
JLS 0:337717573fe7 32 command[3] = (y >> 8) & 0xFF;
JLS 0:337717573fe7 33 command[4] = y & 0xFF;
JLS 0:337717573fe7 34
JLS 0:337717573fe7 35 command[5] = (radius >> 8) & 0xFF;
JLS 0:337717573fe7 36 command[6] = radius & 0xFF;
JLS 0:337717573fe7 37
JLS 0:337717573fe7 38 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 39 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 40 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 41
JLS 0:337717573fe7 42 command[7] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 43 command[8] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 44
JLS 0:337717573fe7 45 writeCOMMAND(command, 9);
JLS 0:337717573fe7 46 }
JLS 0:337717573fe7 47
JLS 0:337717573fe7 48 //****************************************************************************************************
JLS 0:337717573fe7 49 void TFT_4DGL :: triangle(int x1, int y1 , int x2, int y2, int x3, int y3, int color) { // draw a traingle
JLS 0:337717573fe7 50 char command[15]= "";
JLS 0:337717573fe7 51
JLS 0:337717573fe7 52 command[0] = TRIANGLE;
JLS 0:337717573fe7 53
JLS 0:337717573fe7 54 command[1] = (x1 >> 8) & 0xFF;
JLS 0:337717573fe7 55 command[2] = x1 & 0xFF;
JLS 0:337717573fe7 56
JLS 0:337717573fe7 57 command[3] = (y1 >> 8) & 0xFF;
JLS 0:337717573fe7 58 command[4] = y1 & 0xFF;
JLS 0:337717573fe7 59
JLS 0:337717573fe7 60 command[5] = (x2 >> 8) & 0xFF;
JLS 0:337717573fe7 61 command[6] = x2 & 0xFF;
JLS 0:337717573fe7 62
JLS 0:337717573fe7 63 command[7] = (y2 >> 8) & 0xFF;
JLS 0:337717573fe7 64 command[8] = y2 & 0xFF;
JLS 0:337717573fe7 65
JLS 0:337717573fe7 66 command[9] = (x3 >> 8) & 0xFF;
JLS 0:337717573fe7 67 command[10] = x3 & 0xFF;
JLS 0:337717573fe7 68
JLS 0:337717573fe7 69 command[11] = (y3 >> 8) & 0xFF;
JLS 0:337717573fe7 70 command[12] = y3 & 0xFF;
JLS 0:337717573fe7 71
JLS 0:337717573fe7 72 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 73 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 74 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 75
JLS 0:337717573fe7 76 command[13] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 77 command[14] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 78
JLS 0:337717573fe7 79 writeCOMMAND(command, 15);
JLS 0:337717573fe7 80 }
JLS 0:337717573fe7 81
JLS 0:337717573fe7 82 //****************************************************************************************************
JLS 0:337717573fe7 83 void TFT_4DGL :: line(int x1, int y1 , int x2, int y2, int color) { // draw a line
JLS 0:337717573fe7 84 char command[11]= "";
JLS 0:337717573fe7 85
JLS 0:337717573fe7 86 command[0] = LINE;
JLS 0:337717573fe7 87
JLS 0:337717573fe7 88 command[1] = (x1 >> 8) & 0xFF;
JLS 0:337717573fe7 89 command[2] = x1 & 0xFF;
JLS 0:337717573fe7 90
JLS 0:337717573fe7 91 command[3] = (y1 >> 8) & 0xFF;
JLS 0:337717573fe7 92 command[4] = y1 & 0xFF;
JLS 0:337717573fe7 93
JLS 0:337717573fe7 94 command[5] = (x2 >> 8) & 0xFF;
JLS 0:337717573fe7 95 command[6] = x2 & 0xFF;
JLS 0:337717573fe7 96
JLS 0:337717573fe7 97 command[7] = (y2 >> 8) & 0xFF;
JLS 0:337717573fe7 98 command[8] = y2 & 0xFF;
JLS 0:337717573fe7 99
JLS 0:337717573fe7 100 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 101 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 102 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 103
JLS 0:337717573fe7 104 command[9] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 105 command[10] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 106
JLS 0:337717573fe7 107 writeCOMMAND(command, 11);
JLS 0:337717573fe7 108 }
JLS 0:337717573fe7 109
JLS 0:337717573fe7 110 //****************************************************************************************************
JLS 0:337717573fe7 111 void TFT_4DGL :: rectangle(int x1, int y1 , int x2, int y2, int color) { // draw a rectangle
JLS 0:337717573fe7 112 char command[11]= "";
JLS 0:337717573fe7 113
JLS 0:337717573fe7 114 command[0] = RECTANGLE;
JLS 0:337717573fe7 115
JLS 0:337717573fe7 116 command[1] = (x1 >> 8) & 0xFF;
JLS 0:337717573fe7 117 command[2] = x1 & 0xFF;
JLS 0:337717573fe7 118
JLS 0:337717573fe7 119 command[3] = (y1 >> 8) & 0xFF;
JLS 0:337717573fe7 120 command[4] = y1 & 0xFF;
JLS 0:337717573fe7 121
JLS 0:337717573fe7 122 command[5] = (x2 >> 8) & 0xFF;
JLS 0:337717573fe7 123 command[6] = x2 & 0xFF;
JLS 0:337717573fe7 124
JLS 0:337717573fe7 125 command[7] = (y2 >> 8) & 0xFF;
JLS 0:337717573fe7 126 command[8] = y2 & 0xFF;
JLS 0:337717573fe7 127
JLS 0:337717573fe7 128 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 129 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 130 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 131
JLS 0:337717573fe7 132 command[9] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 133 command[10] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 134
JLS 0:337717573fe7 135 writeCOMMAND(command, 11);
JLS 0:337717573fe7 136 }
JLS 0:337717573fe7 137
JLS 0:337717573fe7 138 //****************************************************************************************************
JLS 0:337717573fe7 139 void TFT_4DGL :: ellipse(int x, int y , int radius_x, int radius_y, int color) { // draw an ellipse
JLS 0:337717573fe7 140 char command[11]= "";
JLS 0:337717573fe7 141
JLS 0:337717573fe7 142 command[0] = ELLIPSE;
JLS 0:337717573fe7 143
JLS 0:337717573fe7 144 command[1] = (x >> 8) & 0xFF;
JLS 0:337717573fe7 145 command[2] = x & 0xFF;
JLS 0:337717573fe7 146
JLS 0:337717573fe7 147 command[3] = (y >> 8) & 0xFF;
JLS 0:337717573fe7 148 command[4] = y & 0xFF;
JLS 0:337717573fe7 149
JLS 0:337717573fe7 150 command[5] = (radius_x >> 8) & 0xFF;
JLS 0:337717573fe7 151 command[6] = radius_x & 0xFF;
JLS 0:337717573fe7 152
JLS 0:337717573fe7 153 command[7] = (radius_y >> 8) & 0xFF;
JLS 0:337717573fe7 154 command[8] = radius_y & 0xFF;
JLS 0:337717573fe7 155
JLS 0:337717573fe7 156 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 157 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 158 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 159
JLS 0:337717573fe7 160 command[9] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 161 command[10] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 162
JLS 0:337717573fe7 163 writeCOMMAND(command, 11);
JLS 0:337717573fe7 164 }
JLS 0:337717573fe7 165
JLS 0:337717573fe7 166 //****************************************************************************************************
JLS 0:337717573fe7 167 void TFT_4DGL :: pixel(int x, int y, int color) { // draw a pixel
JLS 0:337717573fe7 168 char command[7]= "";
JLS 0:337717573fe7 169
JLS 0:337717573fe7 170 command[0] = PIXEL;
JLS 0:337717573fe7 171
JLS 0:337717573fe7 172 command[1] = (x >> 8) & 0xFF;
JLS 0:337717573fe7 173 command[2] = x & 0xFF;
JLS 0:337717573fe7 174
JLS 0:337717573fe7 175 command[3] = (y >> 8) & 0xFF;
JLS 0:337717573fe7 176 command[4] = y & 0xFF;
JLS 0:337717573fe7 177
JLS 0:337717573fe7 178 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:337717573fe7 179 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:337717573fe7 180 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:337717573fe7 181
JLS 0:337717573fe7 182 command[5] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:337717573fe7 183 command[6] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:337717573fe7 184
JLS 0:337717573fe7 185 writeCOMMAND(command, 7);
JLS 0:337717573fe7 186 }
JLS 0:337717573fe7 187
JLS 0:337717573fe7 188 //******************************************************************************************************
JLS 0:337717573fe7 189 int TFT_4DGL :: read_pixel(int x, int y) { // read screen info and populate data
JLS 0:337717573fe7 190
JLS 0:337717573fe7 191 char command[5]= "";
JLS 0:337717573fe7 192
JLS 0:337717573fe7 193 command[0] = READPIXEL;
JLS 0:337717573fe7 194
JLS 0:337717573fe7 195 command[1] = (x >> 8) & 0xFF;
JLS 0:337717573fe7 196 command[2] = x & 0xFF;
JLS 0:337717573fe7 197
JLS 0:337717573fe7 198 command[3] = (y >> 8) & 0xFF;
JLS 0:337717573fe7 199 command[4] = y & 0xFF;
JLS 0:337717573fe7 200
JLS 0:337717573fe7 201 int i, temp = 0, color = 0, resp = 0;
JLS 0:337717573fe7 202 char response[2] = "";
JLS 0:337717573fe7 203
JLS 0:337717573fe7 204 freeBUFFER();
JLS 0:337717573fe7 205
JLS 0:337717573fe7 206 for (i = 0; i < 5; i++) { // send all chars to serial port
JLS 0:337717573fe7 207 writeBYTE(command[i]);
JLS 0:337717573fe7 208 }
JLS 0:337717573fe7 209
JLS 0:337717573fe7 210 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:337717573fe7 211
JLS 0:337717573fe7 212 while (_cmd.readable()) {
JLS 0:337717573fe7 213 temp = _cmd.getc();
JLS 0:337717573fe7 214 response[resp++] = (char)temp;
JLS 0:337717573fe7 215 }
JLS 0:337717573fe7 216
JLS 0:337717573fe7 217 color = ((response[0] << 8) + response[1]);
JLS 0:337717573fe7 218
JLS 0:337717573fe7 219 return color; // WARNING : this is 16bits color, not 24bits... need to be fixed
JLS 0:337717573fe7 220 }
JLS 0:337717573fe7 221
JLS 0:337717573fe7 222 //******************************************************************************************************
JLS 0:337717573fe7 223 void TFT_4DGL :: screen_copy(int xs, int ys , int xd, int yd , int width, int height) {
JLS 0:337717573fe7 224
JLS 0:337717573fe7 225 char command[13]= "";
JLS 0:337717573fe7 226
JLS 0:337717573fe7 227 command[0] = SCREENCOPY;
JLS 0:337717573fe7 228
JLS 0:337717573fe7 229 command[1] = (xs >> 8) & 0xFF;
JLS 0:337717573fe7 230 command[2] = xs & 0xFF;
JLS 0:337717573fe7 231
JLS 0:337717573fe7 232 command[3] = (ys >> 8) & 0xFF;
JLS 0:337717573fe7 233 command[4] = ys & 0xFF;
JLS 0:337717573fe7 234
JLS 0:337717573fe7 235 command[5] = (xd >> 8) & 0xFF;
JLS 0:337717573fe7 236 command[6] = xd & 0xFF;
JLS 0:337717573fe7 237
JLS 0:337717573fe7 238 command[7] = (yd >> 8) & 0xFF;
JLS 0:337717573fe7 239 command[8] = yd & 0xFF;
JLS 0:337717573fe7 240
JLS 0:337717573fe7 241 command[9] = (width >> 8) & 0xFF;
JLS 0:337717573fe7 242 command[10] = width & 0xFF;
JLS 0:337717573fe7 243
JLS 0:337717573fe7 244 command[11] = (height >> 8) & 0xFF;
JLS 0:337717573fe7 245 command[12] = height & 0xFF;
JLS 0:337717573fe7 246
JLS 0:337717573fe7 247 writeCOMMAND(command, 13);
JLS 0:337717573fe7 248 }
JLS 0:337717573fe7 249
JLS 0:337717573fe7 250 //****************************************************************************************************
JLS 0:337717573fe7 251 void TFT_4DGL :: pen_size(char mode) { // set pen to SOLID or WIREFRAME
JLS 0:337717573fe7 252 char command[2]= "";
JLS 0:337717573fe7 253
JLS 0:337717573fe7 254 command[0] = PENSIZE;
JLS 0:337717573fe7 255 command[1] = mode;
JLS 0:337717573fe7 256
JLS 0:337717573fe7 257 writeCOMMAND(command, 2);
JLS 0:337717573fe7 258 }
JLS 0:337717573fe7 259
JLS 0:337717573fe7 260 //****************************************************************************************************
JLS 0:337717573fe7 261 // This plays a .wav file from the FAT partition of an uSD Card
JLS 0:337717573fe7 262 // Not really recommended as the speaker on the uLCD-32PT is really bad!
JLS 0:337717573fe7 263 //****************************************************************************************************
JLS 0:337717573fe7 264 void TFT_4DGL :: SD_Card_Wav(char *Filename) {
JLS 0:337717573fe7 265 char command[21]= "";
JLS 0:337717573fe7 266 int Lgt=0;
JLS 0:337717573fe7 267
JLS 0:337717573fe7 268 command[0] = 0x40; //ext_cmd
JLS 0:337717573fe7 269 command[1] = 0x6C; //Play Audio
JLS 0:337717573fe7 270 command[2] = 0x01; //Option 0x00=Return at end, 0x01=Return now, 0x02=Stop, 0x03=Pause, 0x04=Resume, 0x05=Loop.
JLS 0:337717573fe7 271 for(int i=0;Filename[i]!=0x00;i++){
JLS 0:337717573fe7 272 command[i+3] = Filename[i];
JLS 0:337717573fe7 273 Lgt = i;
JLS 0:337717573fe7 274 }
JLS 0:337717573fe7 275 command[Lgt+4] = 0x2E; //.
JLS 0:337717573fe7 276 command[Lgt+5] = 0x77; //w
JLS 0:337717573fe7 277 command[Lgt+6] = 0x61; //a
JLS 0:337717573fe7 278 command[Lgt+7] = 0x76; //v
JLS 0:337717573fe7 279 command[Lgt+8] = 0x00; //terminator
JLS 0:337717573fe7 280
JLS 0:337717573fe7 281 writeCOMMAND(command, Lgt+9);
JLS 0:337717573fe7 282 }
JLS 0:337717573fe7 283
JLS 0:337717573fe7 284 //****************************************************************************************************
JLS 0:337717573fe7 285 // This sets the volume for the speaker on the uLCD-32PT
JLS 0:337717573fe7 286 //****************************************************************************************************
JLS 0:337717573fe7 287 void TFT_4DGL :: Set_Volume(char vol) {
JLS 0:337717573fe7 288
JLS 0:337717573fe7 289 char command[2]= "";
JLS 0:337717573fe7 290
JLS 0:337717573fe7 291 command[0] = 0x76; //cmd
JLS 0:337717573fe7 292 command[1] = vol; //set volume
JLS 0:337717573fe7 293
JLS 0:337717573fe7 294 writeCOMMAND(command, 2);
JLS 0:337717573fe7 295 }
JLS 0:337717573fe7 296
JLS 0:337717573fe7 297 //****************************************************************************************************
JLS 0:337717573fe7 298 // This displays an image on the screen that is stored on the FAT partition of an uSD Card
JLS 0:337717573fe7 299 // Sent Filename, X-pos, Y-pos, Sector Address - Display from the RAW partition is quicker
JLS 0:337717573fe7 300 //****************************************************************************************************
JLS 0:337717573fe7 301 void TFT_4DGL :: uSD_FAT_Image(char *Filename, int x, int y, long s) {
JLS 0:337717573fe7 302 char X_MSB, X_LSB, Y_MSB, Y_LSB, S0, S1, S2, S3;
JLS 0:337717573fe7 303 char command[25]= "";
JLS 0:337717573fe7 304 int Lgt=0;
JLS 0:337717573fe7 305
JLS 0:337717573fe7 306 X_LSB = x&0x00FF;
JLS 0:337717573fe7 307 X_MSB = (x >> 8);
JLS 0:337717573fe7 308 Y_LSB = y&0x00FF;
JLS 0:337717573fe7 309 Y_MSB = (y >> 8);
JLS 0:337717573fe7 310
JLS 0:337717573fe7 311 S0 = (s >> 20)&0x000000FF;
JLS 0:337717573fe7 312 S1 = (s >> 16)&0x0000FF;
JLS 0:337717573fe7 313 S2 = (s >> 8)&0x0000FF;
JLS 0:337717573fe7 314 S3 = s&0x0000FF;;
JLS 0:337717573fe7 315
JLS 0:337717573fe7 316 command[0] = '@'; //ext_cmd
JLS 0:337717573fe7 317 command[1] = 'm'; //FAT Image
JLS 0:337717573fe7 318 for(int i=0;Filename[i]!=0x00;i++){
JLS 0:337717573fe7 319 command[i+2] = Filename[i];
JLS 0:337717573fe7 320 Lgt = i;
JLS 0:337717573fe7 321 }
JLS 0:337717573fe7 322 command[Lgt+3] = '.'; //.
JLS 0:337717573fe7 323 command[Lgt+4] = 'G'; //G
JLS 0:337717573fe7 324 command[Lgt+5] = 'C'; //C
JLS 0:337717573fe7 325 command[Lgt+6] = 'I'; //I
JLS 0:337717573fe7 326 command[Lgt+7] = 0x00; //Terminator
JLS 0:337717573fe7 327 command[Lgt+8] = X_MSB; //X-Position MSB
JLS 0:337717573fe7 328 command[Lgt+9] = X_LSB; //X-Position LSB
JLS 0:337717573fe7 329 command[Lgt+10] = Y_MSB; //Y-Position MSB
JLS 0:337717573fe7 330 command[Lgt+11] = Y_LSB; //Y-Position LSB
JLS 0:337717573fe7 331 command[Lgt+12] = S0; //Sector Address 4 bytes
JLS 0:337717573fe7 332 command[Lgt+13] = S1;
JLS 0:337717573fe7 333 command[Lgt+14] = S2;
JLS 0:337717573fe7 334 command[Lgt+15] = S3;
JLS 0:337717573fe7 335
JLS 0:337717573fe7 336 writeCOMMAND(command, Lgt+16);
JLS 0:337717573fe7 337 }
JLS 0:337717573fe7 338
JLS 0:337717573fe7 339 //****************************************************************************************************
JLS 0:337717573fe7 340 // This displays an image on the screen in the NEW FORMAT
JLS 0:337717573fe7 341 // Sent X-pos, Y-pos, Sector Address - This is the recommended way to display images
JLS 0:337717573fe7 342 //****************************************************************************************************
JLS 0:337717573fe7 343 void TFT_4DGL :: uSD_Image(int x, int y, long s) {
JLS 0:337717573fe7 344 char S1, S2, S3;
JLS 0:337717573fe7 345 char X_MSB, X_LSB, Y_MSB, Y_LSB;
JLS 0:337717573fe7 346 char command[9]= "";
JLS 0:337717573fe7 347
JLS 0:337717573fe7 348 X_LSB = x&0x00FF; //Work out the x position
JLS 0:337717573fe7 349 X_MSB = (x >> 8);
JLS 0:337717573fe7 350 Y_LSB = y&0x00FF; //Work out the y position
JLS 0:337717573fe7 351 Y_MSB = (y >> 8);
JLS 0:337717573fe7 352
JLS 0:337717573fe7 353 S1 = (s >> 16)&0x0000FF; //Work out the sector address
JLS 0:337717573fe7 354 S2 = (s >> 8)&0x0000FF;
JLS 0:337717573fe7 355 S3 = s&0x0000FF;
JLS 0:337717573fe7 356
JLS 0:337717573fe7 357 command[0] = 0x40; //ext_cmd
JLS 0:337717573fe7 358 command[1] = 0x49; //Display image
JLS 0:337717573fe7 359 command[2] = X_MSB; //X position - 2 bytes
JLS 0:337717573fe7 360 command[3] = X_LSB;
JLS 0:337717573fe7 361 command[4] = Y_MSB; //Y position - 2 bytes
JLS 0:337717573fe7 362 command[5] = Y_LSB;
JLS 0:337717573fe7 363 command[6] = S1; //Sector address - 3 bytes
JLS 0:337717573fe7 364 command[7] = S2;
JLS 0:337717573fe7 365 command[8] = S3;
JLS 0:337717573fe7 366
JLS 0:337717573fe7 367 writeCOMMAND(command, 9);
JLS 0:337717573fe7 368 }
JLS 0:337717573fe7 369
JLS 0:337717573fe7 370 //****************************************************************************************************
JLS 0:337717573fe7 371 // This displays an video on the screen in the NEW FORMAT
JLS 0:337717573fe7 372 // Sent X-pos, Y-pos, Sector Address - This is the recommended way to display video
JLS 0:337717573fe7 373 //****************************************************************************************************
JLS 0:337717573fe7 374 void TFT_4DGL :: uSD_Video(int x, int y, long s) {
JLS 0:337717573fe7 375 char S1, S2, S3;
JLS 0:337717573fe7 376 char X_MSB, X_LSB, Y_MSB, Y_LSB;
JLS 0:337717573fe7 377 char command[10]= "";
JLS 0:337717573fe7 378
JLS 0:337717573fe7 379 X_LSB = x&0x00FF;
JLS 0:337717573fe7 380 X_MSB = (x >> 8);
JLS 0:337717573fe7 381 Y_LSB = y&0x00FF;
JLS 0:337717573fe7 382 Y_MSB = (y >> 8);
JLS 0:337717573fe7 383
JLS 0:337717573fe7 384 S1 = (s >> 16)&0x0000FF;
JLS 0:337717573fe7 385 S2 = (s >> 8)&0x0000FF;
JLS 0:337717573fe7 386 S3 = s&0x0000FF;
JLS 0:337717573fe7 387
JLS 0:337717573fe7 388 command[0] = 0x40; //ext_cmd
JLS 0:337717573fe7 389 command[1] = 0x56; //Display video
JLS 0:337717573fe7 390 command[2] = X_MSB; //X position - 2 bytes
JLS 0:337717573fe7 391 command[3] = X_LSB;
JLS 0:337717573fe7 392 command[4] = Y_MSB; //Y position - 2 bytes
JLS 0:337717573fe7 393 command[5] = Y_LSB;
JLS 0:337717573fe7 394 command[6] = 0x00; //delay between frames
JLS 0:337717573fe7 395 command[7] = S1; //Sector address - 3 bytes
JLS 0:337717573fe7 396 command[8] = S2;
JLS 0:337717573fe7 397 command[9] = S3;
JLS 0:337717573fe7 398
JLS 0:337717573fe7 399 writeCOMMAND(command, 10);
JLS 0:337717573fe7 400 }