4D hyperchaotic rossler attractor

Committer:
JLS
Date:
Mon Apr 04 16:14:50 2011 +0000
Revision:
0:276aaf2f7d38

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
JLS 0:276aaf2f7d38 1 //
JLS 0:276aaf2f7d38 2 // TFT_4DGL is a class to drive 4D Systems TFT touch screens
JLS 0:276aaf2f7d38 3 //
JLS 0:276aaf2f7d38 4 // Copyright (C) <2010> Stephane ROCHON <stephane.rochon at free.fr>
JLS 0:276aaf2f7d38 5 //
JLS 0:276aaf2f7d38 6 // TFT_4DGL is free software: you can redistribute it and/or modify
JLS 0:276aaf2f7d38 7 // it under the terms of the GNU General Public License as published by
JLS 0:276aaf2f7d38 8 // the Free Software Foundation, either version 3 of the License, or
JLS 0:276aaf2f7d38 9 // (at your option) any later version.
JLS 0:276aaf2f7d38 10 //
JLS 0:276aaf2f7d38 11 // TFT_4DGL is distributed in the hope that it will be useful,
JLS 0:276aaf2f7d38 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
JLS 0:276aaf2f7d38 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
JLS 0:276aaf2f7d38 14 // GNU General Public License for more details.
JLS 0:276aaf2f7d38 15 //
JLS 0:276aaf2f7d38 16 // You should have received a copy of the GNU General Public License
JLS 0:276aaf2f7d38 17 // along with TFT_4DGL. If not, see <http://www.gnu.org/licenses/>.
JLS 0:276aaf2f7d38 18
JLS 0:276aaf2f7d38 19 #include "mbed.h"
JLS 0:276aaf2f7d38 20 #include "TFT_4DGL.h"
JLS 0:276aaf2f7d38 21
JLS 0:276aaf2f7d38 22 //******************************************************************************************************
JLS 0:276aaf2f7d38 23 void TFT_4DGL :: touch_mode(char mode) { // Send touch mode (WAIT, PRESS, RELEASE or MOVE)
JLS 0:276aaf2f7d38 24
JLS 0:276aaf2f7d38 25 char command[2]= "";
JLS 0:276aaf2f7d38 26
JLS 0:276aaf2f7d38 27 command[0] = GETTOUCH;
JLS 0:276aaf2f7d38 28 command[1] = mode;
JLS 0:276aaf2f7d38 29
JLS 0:276aaf2f7d38 30 writeCOMMAND(command, 2);
JLS 0:276aaf2f7d38 31 }
JLS 0:276aaf2f7d38 32
JLS 0:276aaf2f7d38 33 //******************************************************************************************************
JLS 0:276aaf2f7d38 34 void TFT_4DGL :: get_touch(int *x, int *y) { // Get the touch coordinates
JLS 0:276aaf2f7d38 35
JLS 0:276aaf2f7d38 36 char command[2] = "";
JLS 0:276aaf2f7d38 37
JLS 0:276aaf2f7d38 38 command[0] = GETTOUCH;
JLS 0:276aaf2f7d38 39 command[1] = GETPOSITION;
JLS 0:276aaf2f7d38 40
JLS 0:276aaf2f7d38 41 getTOUCH(command, 2, x, y);
JLS 0:276aaf2f7d38 42 }
JLS 0:276aaf2f7d38 43
JLS 0:276aaf2f7d38 44 //******************************************************************************************************
JLS 0:276aaf2f7d38 45 int TFT_4DGL :: touch_status(void) { // Get the touch screen status
JLS 0:276aaf2f7d38 46
JLS 0:276aaf2f7d38 47 char command[2] = "";
JLS 0:276aaf2f7d38 48
JLS 0:276aaf2f7d38 49 command[0] = GETTOUCH;
JLS 0:276aaf2f7d38 50 command[1] = STATUS;
JLS 0:276aaf2f7d38 51
JLS 0:276aaf2f7d38 52 return getSTATUS(command, 2);
JLS 0:276aaf2f7d38 53 }
JLS 0:276aaf2f7d38 54
JLS 0:276aaf2f7d38 55
JLS 0:276aaf2f7d38 56 //******************************************************************************************************
JLS 0:276aaf2f7d38 57 void TFT_4DGL :: wait_touch(int delay) { // wait until touch within a delay in milliseconds
JLS 0:276aaf2f7d38 58
JLS 0:276aaf2f7d38 59 char command[3]= "";
JLS 0:276aaf2f7d38 60
JLS 0:276aaf2f7d38 61 command[0] = WAITTOUCH;
JLS 0:276aaf2f7d38 62
JLS 0:276aaf2f7d38 63 command[1] = (delay >> 8) & 0xFF;
JLS 0:276aaf2f7d38 64 command[2] = delay & 0xFF;
JLS 0:276aaf2f7d38 65
JLS 0:276aaf2f7d38 66 writeCOMMAND(command, 3);
JLS 0:276aaf2f7d38 67 }
JLS 0:276aaf2f7d38 68
JLS 0:276aaf2f7d38 69 //******************************************************************************************************
JLS 0:276aaf2f7d38 70 void TFT_4DGL :: set_touch(int x1, int y1 , int x2, int y2) { // define touch area
JLS 0:276aaf2f7d38 71
JLS 0:276aaf2f7d38 72 char command[9]= "";
JLS 0:276aaf2f7d38 73
JLS 0:276aaf2f7d38 74 command[0] = SETTOUCH;
JLS 0:276aaf2f7d38 75
JLS 0:276aaf2f7d38 76 command[1] = (x1 >> 8) & 0xFF;
JLS 0:276aaf2f7d38 77 command[2] = x1 & 0xFF;
JLS 0:276aaf2f7d38 78
JLS 0:276aaf2f7d38 79 command[3] = (y1 >> 8) & 0xFF;
JLS 0:276aaf2f7d38 80 command[4] = y1 & 0xFF;
JLS 0:276aaf2f7d38 81
JLS 0:276aaf2f7d38 82 command[5] = (x2 >> 8) & 0xFF;
JLS 0:276aaf2f7d38 83 command[6] = x2 & 0xFF;
JLS 0:276aaf2f7d38 84
JLS 0:276aaf2f7d38 85 command[7] = (y2 >> 8) & 0xFF;
JLS 0:276aaf2f7d38 86 command[8] = y2 & 0xFF;
JLS 0:276aaf2f7d38 87
JLS 0:276aaf2f7d38 88 writeCOMMAND(command, 9);
JLS 0:276aaf2f7d38 89 }
JLS 0:276aaf2f7d38 90
JLS 0:276aaf2f7d38 91 //******************************************************************************************************
JLS 0:276aaf2f7d38 92 // There is no way to have the uLCD-32PT trigger an interrupt when touched.
JLS 0:276aaf2f7d38 93 // This function polls the screen and waits for a touch to regiester
JLS 0:276aaf2f7d38 94 //******************************************************************************************************
JLS 0:276aaf2f7d38 95 void TFT_4DGL :: Pause_Until_Touch(int *x, int *y) { // Actually waits for a TouchScreen release!
JLS 0:276aaf2f7d38 96
JLS 0:276aaf2f7d38 97 char TouchStatus = 0; //Initalise the TouchStatus as 0 = no touch activity
JLS 0:276aaf2f7d38 98 char command[2] = "";
JLS 0:276aaf2f7d38 99
JLS 0:276aaf2f7d38 100 do{
JLS 0:276aaf2f7d38 101 TouchStatus = touch_status(); //Get the touchscreen status
JLS 0:276aaf2f7d38 102 wait(0.1);
JLS 0:276aaf2f7d38 103 }while (TouchStatus != 2);
JLS 0:276aaf2f7d38 104
JLS 0:276aaf2f7d38 105 command[0] = GETTOUCH;
JLS 0:276aaf2f7d38 106 command[1] = GETPOSITION;
JLS 0:276aaf2f7d38 107
JLS 0:276aaf2f7d38 108 getTOUCH(command, 2, x, y);
JLS 0:276aaf2f7d38 109 }