Polynomial Type B - fractal map

Committer:
JLS
Date:
Sat Jan 22 19:01:46 2011 +0000
Revision:
0:25eda589d3ce

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
JLS 0:25eda589d3ce 1 //
JLS 0:25eda589d3ce 2 // TFT_4DGL is a class to drive 4D Systems TFT touch screens
JLS 0:25eda589d3ce 3 //
JLS 0:25eda589d3ce 4 // Copyright (C) <2010> Stephane ROCHON <stephane.rochon at free.fr>
JLS 0:25eda589d3ce 5 //
JLS 0:25eda589d3ce 6 // TFT_4DGL is free software: you can redistribute it and/or modify
JLS 0:25eda589d3ce 7 // it under the terms of the GNU General Public License as published by
JLS 0:25eda589d3ce 8 // the Free Software Foundation, either version 3 of the License, or
JLS 0:25eda589d3ce 9 // (at your option) any later version.
JLS 0:25eda589d3ce 10 //
JLS 0:25eda589d3ce 11 // TFT_4DGL is distributed in the hope that it will be useful,
JLS 0:25eda589d3ce 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
JLS 0:25eda589d3ce 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
JLS 0:25eda589d3ce 14 // GNU General Public License for more details.
JLS 0:25eda589d3ce 15 //
JLS 0:25eda589d3ce 16 // You should have received a copy of the GNU General Public License
JLS 0:25eda589d3ce 17 // along with TFT_4DGL. If not, see <http://www.gnu.org/licenses/>.
JLS 0:25eda589d3ce 18
JLS 0:25eda589d3ce 19 #include "mbed.h"
JLS 0:25eda589d3ce 20 #include "TFT_4DGL.h"
JLS 0:25eda589d3ce 21
JLS 0:25eda589d3ce 22 Serial pc(USBTX,USBRX);
JLS 0:25eda589d3ce 23 //DigitalOut led1(LED1), led2(LED2);
JLS 0:25eda589d3ce 24
JLS 0:25eda589d3ce 25 //******************************************************************************************************
JLS 0:25eda589d3ce 26 TFT_4DGL :: TFT_4DGL(PinName tx, PinName rx, PinName rst) : _cmd(tx, rx), _rst(rst) { // Constructor
JLS 0:25eda589d3ce 27
JLS 0:25eda589d3ce 28 #if DEBUGMODE
JLS 0:25eda589d3ce 29 pc.baud(115200);
JLS 0:25eda589d3ce 30
JLS 0:25eda589d3ce 31 pc.printf("\n\n\n");
JLS 0:25eda589d3ce 32 pc.printf("********************\n\r");
JLS 0:25eda589d3ce 33 pc.printf("TFT_4DGL CONSTRUCTOR\n\r");
JLS 0:25eda589d3ce 34 pc.printf("********************\n\r");
JLS 0:25eda589d3ce 35 #endif
JLS 0:25eda589d3ce 36
JLS 0:25eda589d3ce 37 _rst = 1; // put RESET pin to high to start TFT screen
JLS 0:25eda589d3ce 38
JLS 0:25eda589d3ce 39 reset();
JLS 0:25eda589d3ce 40 autobaud(); // send autobaud command
JLS 0:25eda589d3ce 41 baudrate(256000); // set the initial baudrate to 256kbps - fastest supported by uLCD-32PT
JLS 0:25eda589d3ce 42 cls(); // clear screen
JLS 0:25eda589d3ce 43
JLS 0:25eda589d3ce 44 current_col = 0; // initial cursor col
JLS 0:25eda589d3ce 45 current_row = 0; // initial cursor row
JLS 0:25eda589d3ce 46 current_color = WHITE; // initial text color
JLS 0:25eda589d3ce 47 current_orientation = IS_PORTRAIT; // initial screen orientation
JLS 0:25eda589d3ce 48
JLS 0:25eda589d3ce 49 set_font(FONT_5X7); // initial font
JLS 0:25eda589d3ce 50 text_mode(TRANSPARENT); // initial text mode
JLS 0:25eda589d3ce 51 display_control(0x06,0x00); // initial Image control new format
JLS 0:25eda589d3ce 52 }
JLS 0:25eda589d3ce 53
JLS 0:25eda589d3ce 54 //******************************************************************************************************
JLS 0:25eda589d3ce 55 void TFT_4DGL :: writeBYTE(char c) { // send a BYTE command to screen
JLS 0:25eda589d3ce 56
JLS 0:25eda589d3ce 57 _cmd.putc(c);
JLS 0:25eda589d3ce 58
JLS 0:25eda589d3ce 59 #if DEBUGMODE
JLS 0:25eda589d3ce 60 pc.printf(" Char sent : 0x%02X ",c);
JLS 0:25eda589d3ce 61 pc.putc(c);
JLS 0:25eda589d3ce 62 pc.printf(" \n\r");
JLS 0:25eda589d3ce 63 #endif
JLS 0:25eda589d3ce 64
JLS 0:25eda589d3ce 65 }
JLS 0:25eda589d3ce 66
JLS 0:25eda589d3ce 67 //******************************************************************************************************
JLS 0:25eda589d3ce 68 void TFT_4DGL :: freeBUFFER(void) { // Clear serial buffer before writing command
JLS 0:25eda589d3ce 69
JLS 0:25eda589d3ce 70 while (_cmd.readable()) _cmd.getc(); // clear buffer garbage
JLS 0:25eda589d3ce 71 }
JLS 0:25eda589d3ce 72
JLS 0:25eda589d3ce 73 //******************************************************************************************************
JLS 0:25eda589d3ce 74 int TFT_4DGL :: writeCOMMAND(char *command, int number) { // send several BYTES making a command and return an answer
JLS 0:25eda589d3ce 75
JLS 0:25eda589d3ce 76 #if DEBUGMODE
JLS 0:25eda589d3ce 77 pc.printf("\n\r");
JLS 0:25eda589d3ce 78 pc.printf("New COMMAND : 0x%02X\n\r", command[0]);
JLS 0:25eda589d3ce 79 #endif
JLS 0:25eda589d3ce 80 int i, resp = 0;
JLS 0:25eda589d3ce 81 freeBUFFER();
JLS 0:25eda589d3ce 82
JLS 0:25eda589d3ce 83 for (i = 0; i < number; i++) writeBYTE(command[i]); // send command to serial port
JLS 0:25eda589d3ce 84
JLS 0:25eda589d3ce 85 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:25eda589d3ce 86 if (_cmd.readable()) resp = _cmd.getc(); // read response if any
JLS 0:25eda589d3ce 87 switch (resp) {
JLS 0:25eda589d3ce 88 case ACK : // if OK return 1
JLS 0:25eda589d3ce 89 resp = 1;
JLS 0:25eda589d3ce 90 break;
JLS 0:25eda589d3ce 91 case NAK : // if NOK return -1
JLS 0:25eda589d3ce 92 resp = -1;
JLS 0:25eda589d3ce 93 break;
JLS 0:25eda589d3ce 94 default :
JLS 0:25eda589d3ce 95 resp = 0; // else return 0
JLS 0:25eda589d3ce 96 break;
JLS 0:25eda589d3ce 97 }
JLS 0:25eda589d3ce 98 #if DEBUGMODE
JLS 0:25eda589d3ce 99 pc.printf(" Answer received : %d\n\r",resp);
JLS 0:25eda589d3ce 100 #endif
JLS 0:25eda589d3ce 101
JLS 0:25eda589d3ce 102 return resp;
JLS 0:25eda589d3ce 103 }
JLS 0:25eda589d3ce 104
JLS 0:25eda589d3ce 105 //**************************************************************************
JLS 0:25eda589d3ce 106 void TFT_4DGL :: reset() { // Reset Screen
JLS 0:25eda589d3ce 107
JLS 0:25eda589d3ce 108 _rst = 0; // put RESET pin to low
JLS 0:25eda589d3ce 109 wait_ms(TEMPO); // wait a few milliseconds for command reception
JLS 0:25eda589d3ce 110 _rst = 1; // put RESET back to high
JLS 0:25eda589d3ce 111 wait(3); // wait 3s for screen to restart
JLS 0:25eda589d3ce 112
JLS 0:25eda589d3ce 113 freeBUFFER(); // clean buffer from possible garbage
JLS 0:25eda589d3ce 114 }
JLS 0:25eda589d3ce 115
JLS 0:25eda589d3ce 116 //**************************************************************************
JLS 0:25eda589d3ce 117 void TFT_4DGL :: autobaud() { // send AutoBaud command (9600)
JLS 0:25eda589d3ce 118 char command[1] = "";
JLS 0:25eda589d3ce 119 command[0] = AUTOBAUD;
JLS 0:25eda589d3ce 120 writeCOMMAND(command, 1);
JLS 0:25eda589d3ce 121 }
JLS 0:25eda589d3ce 122
JLS 0:25eda589d3ce 123 //**************************************************************************
JLS 0:25eda589d3ce 124 void TFT_4DGL :: cls() { // clear screen
JLS 0:25eda589d3ce 125 char command[1] = "";
JLS 0:25eda589d3ce 126 command[0] = CLS;
JLS 0:25eda589d3ce 127 writeCOMMAND(command, 1);
JLS 0:25eda589d3ce 128 }
JLS 0:25eda589d3ce 129
JLS 0:25eda589d3ce 130 //**************************************************************************
JLS 0:25eda589d3ce 131 void TFT_4DGL :: version() { // get API version
JLS 0:25eda589d3ce 132 char command[2] = "";
JLS 0:25eda589d3ce 133 command[0] = VERSION;
JLS 0:25eda589d3ce 134 command[1] = OFF;
JLS 0:25eda589d3ce 135 readVERSION(command, 2);
JLS 0:25eda589d3ce 136 }
JLS 0:25eda589d3ce 137
JLS 0:25eda589d3ce 138 //**************************************************************************
JLS 0:25eda589d3ce 139 void TFT_4DGL :: baudrate(long speed) { // set screen baud rate
JLS 0:25eda589d3ce 140 char command[2]= "";
JLS 0:25eda589d3ce 141 command[0] = BAUDRATE;
JLS 0:25eda589d3ce 142 switch (speed) {
JLS 0:25eda589d3ce 143 case 110 :
JLS 0:25eda589d3ce 144 command[1] = BAUD_110;
JLS 0:25eda589d3ce 145 break;
JLS 0:25eda589d3ce 146 case 300 :
JLS 0:25eda589d3ce 147 command[1] = BAUD_300;
JLS 0:25eda589d3ce 148 break;
JLS 0:25eda589d3ce 149 case 600 :
JLS 0:25eda589d3ce 150 command[1] = BAUD_600;
JLS 0:25eda589d3ce 151 break;
JLS 0:25eda589d3ce 152 case 1200 :
JLS 0:25eda589d3ce 153 command[1] = BAUD_1200;
JLS 0:25eda589d3ce 154 break;
JLS 0:25eda589d3ce 155 case 2400 :
JLS 0:25eda589d3ce 156 command[1] = BAUD_2400;
JLS 0:25eda589d3ce 157 break;
JLS 0:25eda589d3ce 158 case 4800 :
JLS 0:25eda589d3ce 159 command[1] = BAUD_4800;
JLS 0:25eda589d3ce 160 break;
JLS 0:25eda589d3ce 161 case 9600 :
JLS 0:25eda589d3ce 162 command[1] = BAUD_9600;
JLS 0:25eda589d3ce 163 break;
JLS 0:25eda589d3ce 164 case 14400 :
JLS 0:25eda589d3ce 165 command[1] = BAUD_14400;
JLS 0:25eda589d3ce 166 break;
JLS 0:25eda589d3ce 167 case 19200 :
JLS 0:25eda589d3ce 168 command[1] = BAUD_19200;
JLS 0:25eda589d3ce 169 break;
JLS 0:25eda589d3ce 170 case 31250 :
JLS 0:25eda589d3ce 171 command[1] = BAUD_31250;
JLS 0:25eda589d3ce 172 break;
JLS 0:25eda589d3ce 173 case 38400 :
JLS 0:25eda589d3ce 174 command[1] = BAUD_38400;
JLS 0:25eda589d3ce 175 break;
JLS 0:25eda589d3ce 176 case 56000 :
JLS 0:25eda589d3ce 177 command[1] = BAUD_56000;
JLS 0:25eda589d3ce 178 break;
JLS 0:25eda589d3ce 179 case 57600 :
JLS 0:25eda589d3ce 180 command[1] = BAUD_57600;
JLS 0:25eda589d3ce 181 break;
JLS 0:25eda589d3ce 182 case 115200 :
JLS 0:25eda589d3ce 183 command[1] = BAUD_115200;
JLS 0:25eda589d3ce 184 break;
JLS 0:25eda589d3ce 185 case 128000 :
JLS 0:25eda589d3ce 186 command[1] = BAUD_128000;
JLS 0:25eda589d3ce 187 break;
JLS 0:25eda589d3ce 188 case 256000 :
JLS 0:25eda589d3ce 189 command[1] = BAUD_256000;
JLS 0:25eda589d3ce 190 break;
JLS 0:25eda589d3ce 191 default :
JLS 0:25eda589d3ce 192 command[1] = BAUD_9600;
JLS 0:25eda589d3ce 193 speed = 9600;
JLS 0:25eda589d3ce 194 break;
JLS 0:25eda589d3ce 195 }
JLS 0:25eda589d3ce 196
JLS 0:25eda589d3ce 197 #if DEBUGMODE
JLS 0:25eda589d3ce 198 pc.printf("\n\r");
JLS 0:25eda589d3ce 199 pc.printf("New COMMAND : 0x%02X\n\r", command[0]);
JLS 0:25eda589d3ce 200 #endif
JLS 0:25eda589d3ce 201
JLS 0:25eda589d3ce 202 int i, resp = 0;
JLS 0:25eda589d3ce 203 freeBUFFER();
JLS 0:25eda589d3ce 204
JLS 0:25eda589d3ce 205 if(speed==256000)
JLS 0:25eda589d3ce 206 speed=281000; //If baud rate is 256K comm at 281k - as instructed by 4DGL
JLS 0:25eda589d3ce 207
JLS 0:25eda589d3ce 208 for (i = 0; i <2; i++) writeBYTE(command[i]); // send command to serial port
JLS 0:25eda589d3ce 209 _cmd.baud(speed); // set mbed to same speed
JLS 0:25eda589d3ce 210
JLS 0:25eda589d3ce 211 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:25eda589d3ce 212
JLS 0:25eda589d3ce 213 if (_cmd.readable()) resp = _cmd.getc(); // read response if any
JLS 0:25eda589d3ce 214 switch (resp) {
JLS 0:25eda589d3ce 215 case ACK : // if OK return 1
JLS 0:25eda589d3ce 216 resp = 1;
JLS 0:25eda589d3ce 217 break;
JLS 0:25eda589d3ce 218 case NAK : // if NOK return -1
JLS 0:25eda589d3ce 219 resp = -1;
JLS 0:25eda589d3ce 220 break;
JLS 0:25eda589d3ce 221 default :
JLS 0:25eda589d3ce 222 resp = 0; // else return 0
JLS 0:25eda589d3ce 223 break;
JLS 0:25eda589d3ce 224 }
JLS 0:25eda589d3ce 225 #if DEBUGMODE
JLS 0:25eda589d3ce 226 pc.printf(" Baudrate reply received : %d\n\r",resp);
JLS 0:25eda589d3ce 227 #endif
JLS 0:25eda589d3ce 228 }
JLS 0:25eda589d3ce 229
JLS 0:25eda589d3ce 230 //******************************************************************************************************
JLS 0:25eda589d3ce 231 int TFT_4DGL :: readVERSION(char *command, int number) { // read screen info and populate data
JLS 0:25eda589d3ce 232
JLS 0:25eda589d3ce 233 int i, temp = 0, resp = 0;
JLS 0:25eda589d3ce 234 char response[5] = "";
JLS 0:25eda589d3ce 235
JLS 0:25eda589d3ce 236 freeBUFFER();
JLS 0:25eda589d3ce 237
JLS 0:25eda589d3ce 238 for (i = 0; i < number; i++) writeBYTE(command[i]); // send all chars to serial port
JLS 0:25eda589d3ce 239
JLS 0:25eda589d3ce 240 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:25eda589d3ce 241
JLS 0:25eda589d3ce 242 while (_cmd.readable()) {
JLS 0:25eda589d3ce 243 temp = _cmd.getc();
JLS 0:25eda589d3ce 244 response[resp++] = (char)temp;
JLS 0:25eda589d3ce 245 }
JLS 0:25eda589d3ce 246 switch (resp) {
JLS 0:25eda589d3ce 247 case 5 : // if OK populate data and return 1
JLS 0:25eda589d3ce 248 type = response[0];
JLS 0:25eda589d3ce 249 revision = response[1];
JLS 0:25eda589d3ce 250 firmware = response[2];
JLS 0:25eda589d3ce 251 reserved1 = response[3];
JLS 0:25eda589d3ce 252 reserved2 = response[4];
JLS 0:25eda589d3ce 253 resp = 1;
JLS 0:25eda589d3ce 254 break;
JLS 0:25eda589d3ce 255 default :
JLS 0:25eda589d3ce 256 resp = 0; // else return 0
JLS 0:25eda589d3ce 257 break;
JLS 0:25eda589d3ce 258 }
JLS 0:25eda589d3ce 259 return resp;
JLS 0:25eda589d3ce 260 }
JLS 0:25eda589d3ce 261
JLS 0:25eda589d3ce 262 //****************************************************************************************************
JLS 0:25eda589d3ce 263 void TFT_4DGL :: background_color(int color) { // set screen background color
JLS 0:25eda589d3ce 264 char command[3]= ""; // input color is in 24bits like 0xRRGGBB
JLS 0:25eda589d3ce 265
JLS 0:25eda589d3ce 266 command[0] = BCKGDCOLOR;
JLS 0:25eda589d3ce 267
JLS 0:25eda589d3ce 268 int red5 = (color >> (16 + 3)) & 0x1F; // get red on 5 bits
JLS 0:25eda589d3ce 269 int green6 = (color >> (8 + 2)) & 0x3F; // get green on 6 bits
JLS 0:25eda589d3ce 270 int blue5 = (color >> (0 + 3)) & 0x1F; // get blue on 5 bits
JLS 0:25eda589d3ce 271
JLS 0:25eda589d3ce 272 command[1] = ((red5 << 3) + (green6 >> 3)) & 0xFF; // first part of 16 bits color
JLS 0:25eda589d3ce 273 command[2] = ((green6 << 5) + (blue5 >> 0)) & 0xFF; // second part of 16 bits color
JLS 0:25eda589d3ce 274
JLS 0:25eda589d3ce 275 writeCOMMAND(command, 3);
JLS 0:25eda589d3ce 276 }
JLS 0:25eda589d3ce 277
JLS 0:25eda589d3ce 278 //****************************************************************************************************
JLS 0:25eda589d3ce 279 void TFT_4DGL :: display_control(char mode, char value) { // set screen mode to value
JLS 0:25eda589d3ce 280 char command[3]= "";
JLS 0:25eda589d3ce 281
JLS 0:25eda589d3ce 282 command[0] = DISPCONTROL;
JLS 0:25eda589d3ce 283 command[1] = mode;
JLS 0:25eda589d3ce 284 command[2] = value;
JLS 0:25eda589d3ce 285
JLS 0:25eda589d3ce 286 if (mode == ORIENTATION) {
JLS 0:25eda589d3ce 287 switch (value) {
JLS 0:25eda589d3ce 288 case LANDSCAPE :
JLS 0:25eda589d3ce 289 current_orientation = IS_LANDSCAPE;
JLS 0:25eda589d3ce 290 break;
JLS 0:25eda589d3ce 291 case LANDSCAPE_R :
JLS 0:25eda589d3ce 292 current_orientation = IS_LANDSCAPE;
JLS 0:25eda589d3ce 293 break;
JLS 0:25eda589d3ce 294 case PORTRAIT :
JLS 0:25eda589d3ce 295 current_orientation = IS_PORTRAIT;
JLS 0:25eda589d3ce 296 break;
JLS 0:25eda589d3ce 297 case PORTRAIT_R :
JLS 0:25eda589d3ce 298 current_orientation = IS_PORTRAIT;
JLS 0:25eda589d3ce 299 break;
JLS 0:25eda589d3ce 300 }
JLS 0:25eda589d3ce 301 set_font(current_font);
JLS 0:25eda589d3ce 302 }
JLS 0:25eda589d3ce 303 writeCOMMAND(command, 3);
JLS 0:25eda589d3ce 304
JLS 0:25eda589d3ce 305 }
JLS 0:25eda589d3ce 306
JLS 0:25eda589d3ce 307 //****************************************************************************************************
JLS 0:25eda589d3ce 308 void TFT_4DGL :: set_volume(char value) { // set sound volume to value
JLS 0:25eda589d3ce 309 char command[2]= "";
JLS 0:25eda589d3ce 310
JLS 0:25eda589d3ce 311 command[0] = SETVOLUME;
JLS 0:25eda589d3ce 312 command[1] = value;
JLS 0:25eda589d3ce 313
JLS 0:25eda589d3ce 314 writeCOMMAND(command, 2);
JLS 0:25eda589d3ce 315 }
JLS 0:25eda589d3ce 316
JLS 0:25eda589d3ce 317
JLS 0:25eda589d3ce 318 //******************************************************************************************************
JLS 0:25eda589d3ce 319 void TFT_4DGL :: getTOUCH(char *command, int number, int *x, int *y) { // read screen info and populate data
JLS 0:25eda589d3ce 320
JLS 0:25eda589d3ce 321 #if DEBUGMODE
JLS 0:25eda589d3ce 322 pc.printf("\n\r");
JLS 0:25eda589d3ce 323 pc.printf("New COMMAND : 0x%02X\n\r", command[0]);
JLS 0:25eda589d3ce 324 #endif
JLS 0:25eda589d3ce 325 int i, temp = 0, resp = 0;
JLS 0:25eda589d3ce 326 char response[5] = "";
JLS 0:25eda589d3ce 327
JLS 0:25eda589d3ce 328 freeBUFFER();
JLS 0:25eda589d3ce 329
JLS 0:25eda589d3ce 330 for (i = 0; i < number; i++) writeBYTE(command[i]); // send all chars to serial port
JLS 0:25eda589d3ce 331
JLS 0:25eda589d3ce 332 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:25eda589d3ce 333
JLS 0:25eda589d3ce 334 while (_cmd.readable()) {
JLS 0:25eda589d3ce 335 temp = _cmd.getc();
JLS 0:25eda589d3ce 336 response[resp++] = (char)temp;
JLS 0:25eda589d3ce 337 }
JLS 0:25eda589d3ce 338
JLS 0:25eda589d3ce 339 #if DEBUGMODE
JLS 0:25eda589d3ce 340 pc.printf(" Answer received %d : 0x%02X 0x%02X 0x%02X 0x%02X\n\r", resp, response[0], response[1], response[2], response[3]);
JLS 0:25eda589d3ce 341 #endif
JLS 0:25eda589d3ce 342
JLS 0:25eda589d3ce 343 switch (resp) {
JLS 0:25eda589d3ce 344 case 4 : // if OK populate data
JLS 0:25eda589d3ce 345 *x = ((response[0]<<8)+ response[1]) * (response[0] != 0xFF);
JLS 0:25eda589d3ce 346 *y = ((response[2]<<8)+ response[3]) * (response[2] != 0xFF);
JLS 0:25eda589d3ce 347 break;
JLS 0:25eda589d3ce 348 default :
JLS 0:25eda589d3ce 349 *x = -1;
JLS 0:25eda589d3ce 350 *y = -1;
JLS 0:25eda589d3ce 351 break;
JLS 0:25eda589d3ce 352 }
JLS 0:25eda589d3ce 353
JLS 0:25eda589d3ce 354 #if DEBUGMODE
JLS 0:25eda589d3ce 355 pc.printf(" X,Y : %03d,%03d\n\r", *x, *y);
JLS 0:25eda589d3ce 356 #endif
JLS 0:25eda589d3ce 357 }
JLS 0:25eda589d3ce 358
JLS 0:25eda589d3ce 359 //******************************************************************************************************
JLS 0:25eda589d3ce 360 int TFT_4DGL :: getSTATUS(char *command, int number) { // read screen info and populate data
JLS 0:25eda589d3ce 361
JLS 0:25eda589d3ce 362 #if DEBUGMODE
JLS 0:25eda589d3ce 363 pc.printf("\n\r");
JLS 0:25eda589d3ce 364 pc.printf("New COMMAND : 0x%02X\n\r", command[0]);
JLS 0:25eda589d3ce 365 #endif
JLS 0:25eda589d3ce 366
JLS 0:25eda589d3ce 367 int i, temp = 0, resp = 0;
JLS 0:25eda589d3ce 368 char response[5] = "";
JLS 0:25eda589d3ce 369
JLS 0:25eda589d3ce 370 freeBUFFER();
JLS 0:25eda589d3ce 371
JLS 0:25eda589d3ce 372 for (i = 0; i < number; i++) writeBYTE(command[i]); // send all chars to serial port
JLS 0:25eda589d3ce 373
JLS 0:25eda589d3ce 374 while (!_cmd.readable()) wait_ms(TEMPO); // wait for screen answer
JLS 0:25eda589d3ce 375
JLS 0:25eda589d3ce 376 while (_cmd.readable()) {
JLS 0:25eda589d3ce 377 temp = _cmd.getc();
JLS 0:25eda589d3ce 378 response[resp++] = (char)temp;
JLS 0:25eda589d3ce 379 }
JLS 0:25eda589d3ce 380 switch (resp) {
JLS 0:25eda589d3ce 381 case 4 :
JLS 0:25eda589d3ce 382 resp = (int)response[1]; // if OK populate data
JLS 0:25eda589d3ce 383 break;
JLS 0:25eda589d3ce 384 default :
JLS 0:25eda589d3ce 385 resp = -1; // else return 0
JLS 0:25eda589d3ce 386 break;
JLS 0:25eda589d3ce 387 }
JLS 0:25eda589d3ce 388
JLS 0:25eda589d3ce 389 #if DEBUGMODE
JLS 0:25eda589d3ce 390 pc.printf(" Answer received : %d\n\r", resp);
JLS 0:25eda589d3ce 391 #endif
JLS 0:25eda589d3ce 392
JLS 0:25eda589d3ce 393 return resp;
JLS 0:25eda589d3ce 394 }