Changes done in ECG and BT

Dependencies:   SDFileSystem ds3231 eeprom_Nikita mbed testUniGraphic_150217

Fork of merged_code2_20sept_2017_4th_oct_2017 by nikita teggi

Committer:
suhasini
Date:
Sat Apr 01 06:37:02 2017 +0000
Revision:
6:5e33a0f01476
Parent:
5:a3ea7c82b7e1
Child:
7:11f926351d8f
Has all three functionalities-ECG, BG, BP and have resolved jumping issue. Have added return functionality from BP and SYS_CONFIG screens.; But still facing "hanging issue" whenever BP test is performed first.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
nikitateggi 0:c47fb0c1bbf6 1 #include "mbed.h"
nikitateggi 0:c47fb0c1bbf6 2 #include "ili9325.h"
nikitateggi 0:c47fb0c1bbf6 3 #include "lcd_base.h"
nikitateggi 0:c47fb0c1bbf6 4 #include "display_modules.h"
nikitateggi 0:c47fb0c1bbf6 5 #include "touch_modules.h"
nikitateggi 1:8316c23ec6b9 6 #include "ecg_dec.h"
nikitateggi 1:8316c23ec6b9 7 #include "touch_modules.h"
nikitateggi 1:8316c23ec6b9 8 #include "glc.h"
nikitateggi 3:9a06c2bed650 9 #include "bp.h"
nikitateggi 1:8316c23ec6b9 10 #include "sdcard.h"
nikitateggi 4:6bd81bb1790d 11 #include "eeprom_pgm.h"
nikitateggi 0:c47fb0c1bbf6 12
nikitateggi 1:8316c23ec6b9 13
nikitateggi 0:c47fb0c1bbf6 14 Serial gc(USBTX, USBRX);
nikitateggi 0:c47fb0c1bbf6 15 DigitalIn q1(PTB11);
nikitateggi 0:c47fb0c1bbf6 16 DigitalIn q(PTB8);
nikitateggi 1:8316c23ec6b9 17 //Serial ble(PTC4,PTC3);
nikitateggi 0:c47fb0c1bbf6 18
nikitateggi 0:c47fb0c1bbf6 19
nikitateggi 0:c47fb0c1bbf6 20
nikitateggi 0:c47fb0c1bbf6 21 int main(){
nikitateggi 0:c47fb0c1bbf6 22
nikitateggi 0:c47fb0c1bbf6 23
nikitateggi 3:9a06c2bed650 24 unsigned char state;
nikitateggi 3:9a06c2bed650 25 unsigned char state1;
nikitateggi 3:9a06c2bed650 26 unsigned char nstate;
nikitateggi 3:9a06c2bed650 27 unsigned char nstate1;
nikitateggi 3:9a06c2bed650 28 int pid=0; // patient ID
nikitateggi 3:9a06c2bed650 29 unsigned char flag=0;
nikitateggi 3:9a06c2bed650 30 unsigned char ecg_flag=0;
nikitateggi 3:9a06c2bed650 31 unsigned char glc_flag=0;
nikitateggi 1:8316c23ec6b9 32
nikitateggi 3:9a06c2bed650 33
nikitateggi 1:8316c23ec6b9 34 DisableTouch();
nikitateggi 1:8316c23ec6b9 35 gc.baud(115200);
nikitateggi 1:8316c23ec6b9 36
nikitateggi 1:8316c23ec6b9 37 init_screen(); //initialize lcd
nikitateggi 1:8316c23ec6b9 38 screen_main(); // display of main screen
nikitateggi 0:c47fb0c1bbf6 39 state=1;
nikitateggi 1:8316c23ec6b9 40 flag=0;
nikitateggi 1:8316c23ec6b9 41 nstate=state;
nikitateggi 0:c47fb0c1bbf6 42 EnableTouch(); // enable touch function
nikitateggi 0:c47fb0c1bbf6 43
nikitateggi 0:c47fb0c1bbf6 44 while(1)
nikitateggi 0:c47fb0c1bbf6 45 {
nikitateggi 3:9a06c2bed650 46
nikitateggi 4:6bd81bb1790d 47 detect_touch(); // determine the touch points
nikitateggi 1:8316c23ec6b9 48
nikitateggi 4:6bd81bb1790d 49 switch(state) // state for touch
nikitateggi 0:c47fb0c1bbf6 50 {
nikitateggi 0:c47fb0c1bbf6 51 case 1: state1=touch_main(); // determining the touch for main screen
nikitateggi 0:c47fb0c1bbf6 52 state=0;
nikitateggi 1:8316c23ec6b9 53 nstate1=state1;
nikitateggi 3:9a06c2bed650 54 break;
nikitateggi 0:c47fb0c1bbf6 55
nikitateggi 0:c47fb0c1bbf6 56 case 2:
nikitateggi 4:6bd81bb1790d 57 state1=touch_main_1(); // determining the touch for SYSTEM CONFIGURATION screen
nikitateggi 0:c47fb0c1bbf6 58 state=0;
nikitateggi 3:9a06c2bed650 59 nstate1=state1;
nikitateggi 0:c47fb0c1bbf6 60 break;
nikitateggi 0:c47fb0c1bbf6 61
nikitateggi 0:c47fb0c1bbf6 62 case 3:
nikitateggi 4:6bd81bb1790d 63 state1=touch_main_2(); //// determining the touch for TEST screen
nikitateggi 4:6bd81bb1790d 64
nikitateggi 0:c47fb0c1bbf6 65 state=0;
nikitateggi 1:8316c23ec6b9 66 nstate1=state1;
nikitateggi 0:c47fb0c1bbf6 67 break;
nikitateggi 0:c47fb0c1bbf6 68
nikitateggi 0:c47fb0c1bbf6 69 case 4:
nikitateggi 4:6bd81bb1790d 70 state1=touch_glc(); // determining the touch for GLC screen
nikitateggi 1:8316c23ec6b9 71 state=0;
nikitateggi 1:8316c23ec6b9 72 nstate1=state1;
nikitateggi 1:8316c23ec6b9 73 break;
nikitateggi 1:8316c23ec6b9 74
nikitateggi 1:8316c23ec6b9 75 case 5:
nikitateggi 4:6bd81bb1790d 76 state1=touch_ecg(); // determining the touch for ECG screen
nikitateggi 1:8316c23ec6b9 77 state=0;
nikitateggi 3:9a06c2bed650 78 nstate1=state1;
nikitateggi 3:9a06c2bed650 79 break;
nikitateggi 4:6bd81bb1790d 80 case 6:
nikitateggi 4:6bd81bb1790d 81 state1=touch_ret(); // determining the touch for returning back to the main screen
nikitateggi 0:c47fb0c1bbf6 82 state=0;
nikitateggi 3:9a06c2bed650 83 nstate1=state1;
nikitateggi 1:8316c23ec6b9 84 break;
nikitateggi 1:8316c23ec6b9 85
nikitateggi 4:6bd81bb1790d 86 case 7:
suhasini 5:a3ea7c82b7e1 87 state1=touch_again_ecg(); // determining the touch when readings are taken more than once screen
nikitateggi 1:8316c23ec6b9 88 state=0;
nikitateggi 1:8316c23ec6b9 89 nstate1=state1;
nikitateggi 1:8316c23ec6b9 90 break;
nikitateggi 0:c47fb0c1bbf6 91
nikitateggi 3:9a06c2bed650 92 case 8:
nikitateggi 4:6bd81bb1790d 93 state1=touch_bp(); // determining the touch for BP screen
nikitateggi 3:9a06c2bed650 94 state=0;
nikitateggi 3:9a06c2bed650 95 nstate1=state1;
nikitateggi 3:9a06c2bed650 96 break;
nikitateggi 3:9a06c2bed650 97
suhasini 5:a3ea7c82b7e1 98 case 9: state1=touch_again_glc();
suhasini 5:a3ea7c82b7e1 99 state=0;
suhasini 5:a3ea7c82b7e1 100 nstate1=state1;
suhasini 5:a3ea7c82b7e1 101 break;
nikitateggi 3:9a06c2bed650 102
nikitateggi 1:8316c23ec6b9 103 case 10 : DisableTouch();
nikitateggi 1:8316c23ec6b9 104 wait_ms(300);
nikitateggi 1:8316c23ec6b9 105 EnableTouch();
nikitateggi 3:9a06c2bed650 106 state=nstate;
nikitateggi 3:9a06c2bed650 107 break;
suhasini 5:a3ea7c82b7e1 108
suhasini 5:a3ea7c82b7e1 109
suhasini 5:a3ea7c82b7e1 110 case 11: state1=touch_again_bp();
suhasini 5:a3ea7c82b7e1 111 state=0;
suhasini 5:a3ea7c82b7e1 112 nstate1=state1;
suhasini 5:a3ea7c82b7e1 113 break;
suhasini 5:a3ea7c82b7e1 114
suhasini 5:a3ea7c82b7e1 115
nikitateggi 4:6bd81bb1790d 116 default : DisableTouch();
nikitateggi 1:8316c23ec6b9 117 wait_ms(300);
nikitateggi 1:8316c23ec6b9 118 EnableTouch();
nikitateggi 3:9a06c2bed650 119 state=nstate;
nikitateggi 3:9a06c2bed650 120 break;
nikitateggi 1:8316c23ec6b9 121
nikitateggi 0:c47fb0c1bbf6 122 }
nikitateggi 0:c47fb0c1bbf6 123
nikitateggi 0:c47fb0c1bbf6 124
nikitateggi 0:c47fb0c1bbf6 125
nikitateggi 0:c47fb0c1bbf6 126
nikitateggi 0:c47fb0c1bbf6 127
nikitateggi 4:6bd81bb1790d 128 switch(state1) // state for display screens
nikitateggi 0:c47fb0c1bbf6 129 {
nikitateggi 4:6bd81bb1790d 130
nikitateggi 1:8316c23ec6b9 131
nikitateggi 3:9a06c2bed650 132 case 1: DisableTouch();
nikitateggi 4:6bd81bb1790d 133 screen_main(); // main screen
nikitateggi 1:8316c23ec6b9 134 state1=0;
nikitateggi 1:8316c23ec6b9 135 state=1;
nikitateggi 1:8316c23ec6b9 136 nstate=state;
nikitateggi 1:8316c23ec6b9 137 flag=0;
nikitateggi 4:6bd81bb1790d 138 ecg_flag=0; // ecg, glc flag to determine whether the readings are taken more than once
nikitateggi 1:8316c23ec6b9 139 glc_flag=0;
nikitateggi 3:9a06c2bed650 140 EnableTouch();
nikitateggi 1:8316c23ec6b9 141 break;
nikitateggi 1:8316c23ec6b9 142
nikitateggi 3:9a06c2bed650 143 case 2: DisableTouch();
nikitateggi 4:6bd81bb1790d 144 screen_main_1(); // System configration screen
nikitateggi 0:c47fb0c1bbf6 145 state1=0;
nikitateggi 0:c47fb0c1bbf6 146 state=2;
nikitateggi 1:8316c23ec6b9 147 nstate=state;
nikitateggi 3:9a06c2bed650 148 EnableTouch();
nikitateggi 0:c47fb0c1bbf6 149 break;
nikitateggi 0:c47fb0c1bbf6 150
nikitateggi 3:9a06c2bed650 151 case 3: DisableTouch();
nikitateggi 1:8316c23ec6b9 152 if (flag==0)
nikitateggi 1:8316c23ec6b9 153 {
nikitateggi 4:6bd81bb1790d 154 //pid=pid+1;
nikitateggi 4:6bd81bb1790d 155 pid=eprom_read(1); // reading the patient id from eeprom
nikitateggi 4:6bd81bb1790d 156 pid=pid+1;
nikitateggi 4:6bd81bb1790d 157 eprom_write(1,pid); // writing the patient id to eeprom
nikitateggi 1:8316c23ec6b9 158 screen_main_2(pid);
nikitateggi 4:6bd81bb1790d 159 sd_open_GLCfilee(pid); // only opening the glc,bp and ecg file
nikitateggi 1:8316c23ec6b9 160 sd_close();
nikitateggi 2:3b7b71bfc941 161 sd_open_ECGfilee(pid);
nikitateggi 1:8316c23ec6b9 162 sd_close();
nikitateggi 4:6bd81bb1790d 163 sd_open_BPfilee(pid);
nikitateggi 1:8316c23ec6b9 164 sd_close();
nikitateggi 1:8316c23ec6b9 165 flag=1;
nikitateggi 1:8316c23ec6b9 166 }
nikitateggi 1:8316c23ec6b9 167 else
nikitateggi 1:8316c23ec6b9 168 {
nikitateggi 4:6bd81bb1790d 169 screen_main_2(pid); // TEST screen
nikitateggi 1:8316c23ec6b9 170 }
nikitateggi 1:8316c23ec6b9 171
nikitateggi 1:8316c23ec6b9 172 state1=0;
nikitateggi 1:8316c23ec6b9 173 state=3;
nikitateggi 1:8316c23ec6b9 174 nstate=state;
nikitateggi 3:9a06c2bed650 175 EnableTouch();
nikitateggi 1:8316c23ec6b9 176 break;
nikitateggi 0:c47fb0c1bbf6 177
nikitateggi 3:9a06c2bed650 178 case 4: DisableTouch();
nikitateggi 4:6bd81bb1790d 179 if (glc_flag==1) // glc_flag=1 when already the reading has been taken
nikitateggi 1:8316c23ec6b9 180 {
nikitateggi 4:6bd81bb1790d 181 screen_again();
nikitateggi 1:8316c23ec6b9 182 state1=0;
suhasini 5:a3ea7c82b7e1 183 state=9;
nikitateggi 1:8316c23ec6b9 184 nstate=state;
nikitateggi 1:8316c23ec6b9 185 }
nikitateggi 1:8316c23ec6b9 186 else
nikitateggi 4:6bd81bb1790d 187 { screen_glc(); // glc screen
nikitateggi 0:c47fb0c1bbf6 188 state1=0;
nikitateggi 0:c47fb0c1bbf6 189 state=4;
nikitateggi 1:8316c23ec6b9 190 nstate=state;
nikitateggi 1:8316c23ec6b9 191 }
nikitateggi 3:9a06c2bed650 192 EnableTouch();
nikitateggi 3:9a06c2bed650 193
nikitateggi 0:c47fb0c1bbf6 194 break;
nikitateggi 1:8316c23ec6b9 195
nikitateggi 1:8316c23ec6b9 196
nikitateggi 3:9a06c2bed650 197 case 5: DisableTouch();
nikitateggi 1:8316c23ec6b9 198 if (ecg_flag==1)
nikitateggi 1:8316c23ec6b9 199 {
nikitateggi 1:8316c23ec6b9 200 screen_again();
nikitateggi 1:8316c23ec6b9 201 state1=0;
nikitateggi 1:8316c23ec6b9 202 state=7;
nikitateggi 1:8316c23ec6b9 203 nstate=state;
nikitateggi 1:8316c23ec6b9 204 }
nikitateggi 1:8316c23ec6b9 205
nikitateggi 1:8316c23ec6b9 206 else
nikitateggi 1:8316c23ec6b9 207 {
nikitateggi 4:6bd81bb1790d 208 screen_ecg(); //ecg main screen
nikitateggi 1:8316c23ec6b9 209 state1=0;
nikitateggi 1:8316c23ec6b9 210 state=5;
nikitateggi 1:8316c23ec6b9 211 nstate=state;
nikitateggi 1:8316c23ec6b9 212 }
nikitateggi 3:9a06c2bed650 213 EnableTouch();
nikitateggi 1:8316c23ec6b9 214 break;
nikitateggi 1:8316c23ec6b9 215
nikitateggi 3:9a06c2bed650 216 case 6: DisableTouch();
nikitateggi 4:6bd81bb1790d 217 screen_bp(); // bp main screen
suhasini 6:5e33a0f01476 218 //EnableTouch();
nikitateggi 3:9a06c2bed650 219 state1=0;
nikitateggi 3:9a06c2bed650 220 state=8;
suhasini 6:5e33a0f01476 221 nstate=state; ///////
suhasini 6:5e33a0f01476 222 EnableTouch(); ///////
nikitateggi 3:9a06c2bed650 223 break;
nikitateggi 3:9a06c2bed650 224
nikitateggi 3:9a06c2bed650 225
nikitateggi 3:9a06c2bed650 226
nikitateggi 3:9a06c2bed650 227
nikitateggi 3:9a06c2bed650 228
nikitateggi 4:6bd81bb1790d 229 case 7: DisableTouch();
nikitateggi 4:6bd81bb1790d 230 glc(pid); // glc measurement
nikitateggi 1:8316c23ec6b9 231 glc_flag=1;
nikitateggi 1:8316c23ec6b9 232 wait(5);
nikitateggi 4:6bd81bb1790d 233 state1=0;
nikitateggi 4:6bd81bb1790d 234 screen_glc_2();
nikitateggi 4:6bd81bb1790d 235 state=6;;
nikitateggi 1:8316c23ec6b9 236 // gc.printf("%d", state);
suhasini 6:5e33a0f01476 237 nstate=state; //////////////
nikitateggi 3:9a06c2bed650 238 EnableTouch();
nikitateggi 1:8316c23ec6b9 239 break;
nikitateggi 1:8316c23ec6b9 240
nikitateggi 3:9a06c2bed650 241 case 8: DisableTouch();
nikitateggi 4:6bd81bb1790d 242 ecg_countdown(); // countdown before ecg capture
nikitateggi 4:6bd81bb1790d 243 ecg(pid); // capturing ecg
nikitateggi 1:8316c23ec6b9 244 state1=0;
nikitateggi 1:8316c23ec6b9 245 screen_ecg_2();
nikitateggi 1:8316c23ec6b9 246 state=6;
nikitateggi 1:8316c23ec6b9 247 nstate=state;
nikitateggi 1:8316c23ec6b9 248 ecg_flag=1;
nikitateggi 4:6bd81bb1790d 249 // ble.printf("ecg");
nikitateggi 4:6bd81bb1790d 250 EnableTouch();
nikitateggi 1:8316c23ec6b9 251 break;
nikitateggi 1:8316c23ec6b9 252
nikitateggi 1:8316c23ec6b9 253
nikitateggi 4:6bd81bb1790d 254 /*case 9:
nikitateggi 3:9a06c2bed650 255 DisableTouch();
nikitateggi 4:6bd81bb1790d 256 screen_glc_2();
nikitateggi 4:6bd81bb1790d 257 state1=0;
nikitateggi 1:8316c23ec6b9 258 state=6;
nikitateggi 1:8316c23ec6b9 259 nstate=state;
nikitateggi 3:9a06c2bed650 260 EnableTouch();
nikitateggi 4:6bd81bb1790d 261 break;*/
nikitateggi 3:9a06c2bed650 262
suhasini 5:a3ea7c82b7e1 263 case 9:
nikitateggi 3:9a06c2bed650 264 DisableTouch();
nikitateggi 4:6bd81bb1790d 265 screen_bp2(); // bp main screen
suhasini 6:5e33a0f01476 266 bp_countdown(); // countdown for bp
nikitateggi 4:6bd81bb1790d 267 bp(); // measuring bp
nikitateggi 3:9a06c2bed650 268 state1=0;
nikitateggi 3:9a06c2bed650 269 // wait(1);
nikitateggi 3:9a06c2bed650 270 state=6;
nikitateggi 3:9a06c2bed650 271 nstate=state;
nikitateggi 3:9a06c2bed650 272 EnableTouch();
nikitateggi 3:9a06c2bed650 273 break;
nikitateggi 3:9a06c2bed650 274
nikitateggi 3:9a06c2bed650 275
nikitateggi 3:9a06c2bed650 276
nikitateggi 1:8316c23ec6b9 277 default :
nikitateggi 3:9a06c2bed650 278
nikitateggi 1:8316c23ec6b9 279 state1=nstate1;
nikitateggi 1:8316c23ec6b9 280 break;
nikitateggi 1:8316c23ec6b9 281
nikitateggi 0:c47fb0c1bbf6 282
nikitateggi 0:c47fb0c1bbf6 283 }
nikitateggi 0:c47fb0c1bbf6 284
nikitateggi 0:c47fb0c1bbf6 285
nikitateggi 0:c47fb0c1bbf6 286
nikitateggi 0:c47fb0c1bbf6 287
nikitateggi 0:c47fb0c1bbf6 288
nikitateggi 0:c47fb0c1bbf6 289 }
nikitateggi 0:c47fb0c1bbf6 290
nikitateggi 0:c47fb0c1bbf6 291
nikitateggi 0:c47fb0c1bbf6 292 }
nikitateggi 0:c47fb0c1bbf6 293
nikitateggi 0:c47fb0c1bbf6 294
nikitateggi 0:c47fb0c1bbf6 295
nikitateggi 0:c47fb0c1bbf6 296
nikitateggi 0:c47fb0c1bbf6 297
nikitateggi 0:c47fb0c1bbf6 298
nikitateggi 1:8316c23ec6b9 299