-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTFT_VFO_SPF_v2_5.ino
663 lines (567 loc) · 25.1 KB
/
TFT_VFO_SPF_v2_5.ino
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
/* Arduino Sketch to control Si5351 for generating VFO and BFO signals for Bitx or any multiband transceiver
Uses MCUFRIEND 2.4 inch display with touch screen for controlling all functions. The display and a extension board sit piggy back on the Arduino Mega board.
SP Bhatnagar VU2SPF , [email protected]
with
Joe Basque VE1BWV, [email protected]
Released under GNU GPL3.0
The Author VU2SPF respectfully and humbly acknowledes the fine contributions of authors of various libraries and other similar projects for publishing their
code for the benefit of HAMS and other electronic enthusiasts. Ideas from many of these may reflect in this work. There is inspiration from OM Rob Lae g8vlq in initial screen
layout. Heartfelt Thanks to all users and testers for encouragement.
There are lot of possible additions / upgrades and improvements. Please suggest or correct and publish your changes for the benefit of all HAMS.
Efforts of Joe Basque VE1BWV in testing and improving the program and promoting through his videos and FB etc are thankfully
acknowledged. His constant encouragement and suggestions have been wonderful.
*/
#define Ver "V2.5" // 18/9/2017 Added Transmit Time out Function in F1 touch button, User selects time out for Tx, 19/9/17 Added Active PTT input (goes high) eg from
//5Vregulator, added timeout counter, 2.5a 20/9/17 Corrected tx switch toggle type as well as continuous 5v type
//2.5b 21/9/17 corrected bfo updation in vfo 2.5c 21/9/17 added offset in vfo 2.5d corrected vfo change with memory in M
// 2.5e 24/9/17 Corrected band change with Mem change
//#define Ver "V2.4" // 14/9/2017 Removed message dsplay at bottom, mesgs in buttons, horizontal S meter(avg 10), bfo locking for Fixed BFO syst,
//#define Ver "V2.3" //10/9/17 Freq Lock during Transmit
//#define Ver "V2.2" //9/9/17 Corrected step retention during step change and implemented PTT (touch)
//#define Ver "V2.2" //7/9/17 Switch debounce corrected
//#define Ver "V2.1" // 3/9/2017 corrected elegoo display parameters as per Joe's corrections, colors adjusted
//#define Ver "V2.0" // 1/9/17 making display independent of size and resolution, make common functions to be used by both touch and physical buttons
//---------------
//#define Ver "V1.07" // 16/7/17 minor correctons in band change and display with changing VFOs
//#define Ver "V1.06" // 16/7/17 Corrected band change, Sideband flip and bfo display problems
//#define Ver "V1.05" // 7/7/17 based on practical experimentations wih Bitx acive areas in buttons shrunk from all sides by few pixels.
//#define Ver "V1.04" // 15th June Tidied up display and added 4 fn buttons on 5th row To be assigned later
//#define Ver "V1.03" // 14th June 2017 Optimization and shorter band table
//#define Ver "V1.02" // 9th June 2017 , Optimized prog and minor changes
//#define Ver "V1.01" // 2nd June 2017 Tested with 5351 board and Multiband Bitx
#include <EEPROM.h>
#include "EEPROMAnything.h"
#include <Wire.h>
#include <avr/io.h>
//--------------------Installable Libraries-----------------------------------------------------------------------
#include <Rotary.h> // https://github.com/brianlow/Rotary
#include <si5351.h> // https://github.com/etherkit/Si5351Arduino
#include <Adafruit_GFX.h> // Core graphics library located at adafuit website https://github.com/adafruit/Adafruit-GFX-Library
#include <MCUFRIEND_kbv.h> // https://github.com/prenticedavid/MCUFRIEND_kbv
#include "TouchScreen.h" // https://github.com/adafruit/Touch-Screen-Library
//-----------------------USER SELECTABLE DEFINITIONS---------------------------------------------------------------
// ** // Bitx model specific defines - User Selectable
//#define FIXED_BFO // in HF Sig's BITX40 BFO is fixed Oscillator 11997000UL
// in other models BFO may be generated by one of the outputs of 5351 so variable
//#define IF_12MHZ // HFSig's 12 MHz xtals used
//#define elegoo923 // Joe's 923elegoo displ
#define si5351correction 0 // IF THERE IS ANY (check using calibrate program in the etherkit Si5351 library examples)
#define MCUF0x154 // VU2SPF's test display
#define IF_10MHZ
//pin allocations for input buttons (User selectable )
#define BandSelect 53
#define SideBandSelect 52
#define MEM 51
#define SAVE 50
#define VFO 49
#define STEP 48
#define BF 47
#define VtoMEM 46
#define F1 45
#define F2 44
#define F3 43
#define F4 42
#define ENCODER_A 67 // Encoder pin A is A13 on Mega
#define ENCODER_B 68 // Encoder pin B is A14 on Mega
#define ENCODER_BTN 37
#define PTT_Input 16 // first pin on top towards arduino
bool active_PTT_in = false; // if PTT remains high during QSO make it true (say from 5v in PA), false means toggle active low (like normal mic PTT)
#define PTT_Output 17 // second pin on top
#define SENSOR 66 // Analog Pin A12 for the S Meter function
int ts_delay = 80; // delay between touch button to reduce sensitivity
unsigned long Tx_timeout = 20; // time in sec upto which Tx works continuosly then goes to Rx
int offset = 0; // offsets determined experimentally
volatile uint32_t if_offset = 1500;
//-------------------------------------------------------------------------------------
//function prototypes
void dispPos();
void setup_vfo_screen();
void display_msg(int xposn, String msg);
void init_eprom();
void read_eprom();
void set_vfo();
void set_bfo();
void display_frequency();
void display_vfo();
void display_band();
void display_step();
void display_sideband();
void display_mem();
void display_bfo();
void set_band();
void band_incr();
void band_decr();
int get_button(int x);
void step_decr();
void step_incr();
#define LCD_CS A3 // Chip Select goes to Analog 3 //**? Are these fixed
#define LCD_CD A2 // Command/Data goes to Analog 2
#define LCD_WR A1 // LCD Write goes to Analog 1
#define LCD_RD A0 // LCD Read goes to Analog 0
#define LCD_RESET A4 // Can alternately just connect to Arduino's reset pin
// Assign human-readable names to some common 16-bit color values:
#define BLACK 0x0000 /* 0, 0, 0 */
#define LIGHTGREY 0xC618 /* 192, 192, 192 */
#define GREY 0x7BEF /* 128, 128, 128 */
#define BLUE 0x001F /* 0, 0, 255 */
#define RED 0xF800 /* 255, 0, 0 */
#define YELLOW 0xFFE0 /* 255, 255, 0 */
#define WHITE 0xFFFF /* 255, 255, 255 */
#define ORANGE 0xFD20 /* 255, 165, 0 */
#define GREEN 0x07E0
#define CYAN 0x07FF
#define MAGENTA 0xF81F
// EXTRA Color definitions thanks Joe Basque
#define NAVY 0x000F /* 0, 0, 128 */
#define DARKGREEN 0x03E0 /* 0, 128, 0 */
#define DARKCYAN 0x03EF /* 0, 128, 128 */
#define MAROON 0x7800 /* 128, 0, 0 */
#define PURPLE 0x780F /* 128, 0, 128 */
#define OLIVE 0x7BE0 /* 128, 128, 0 */
#define DARKGREY 0x7BEF /* 128, 128, 128 */
#define GREENYELLOW 0xAFE5 /* 173, 255, 47 */
#define PINK 0xF81F
// most mcufriend shields use these pins and Portrait mode: // **? can we auto define these pins
uint8_t YP; // must be an analog pin, use "An" notation!
uint8_t XM; // must be an analog pin, use "An" notation!
uint8_t YM; // can be a digital pin
uint8_t XP; // can be a digital pin
//Touch coordinates determined by one of the sample programs provided with touch screen library
uint16_t TS_LEFT; // Touch Screen Left edge
uint16_t TS_RT; // Touch Screen right edge
uint16_t TS_TOP; // Touch Screen Top edge
uint16_t TS_BOT; // Touch Screen Bottom edge
//--------------------------------------------------------------------------------------
Si5351 si5351;
Rotary r = Rotary(ENCODER_A, ENCODER_B);
MCUFRIEND_kbv tft;
TouchScreen ts = TouchScreen(XP, YP, XM, YM, 300);
TSPoint tp;
#define MINPRESSURE 20
#define MAXPRESSURE 1000
//--------------------------------------------------------------------------------------
boolean txstatus = false; // Rx = False Tx = True
volatile uint32_t bfo, bfo_USB, bfo_LSB, bfo_A, bfo_B, bfo_M; //The bfo frequency is added to or subtracted from the vfo frequency in the "Loop()"
volatile uint32_t vfo , vfo_tx;
volatile uint32_t vfo_A = 7050000UL, vfo_B = 7130000UL, vfo_M = 14000000UL ; // temp values // either vfo A or B or mem channel is selected for output at any time
boolean vfo_A_sel = true, vfo_B_sel = false, vfo_M_sel = false; // true for vfo selected
boolean changed_f = 0; // indicating need for updating display
boolean xch_M = 0; // flag for xchged mem in V > M
uint16_t sideband, sb_A, sb_B, sb_M;
uint16_t LSB = 1, USB = 2;
// display step size and radix
String step_sz_txt[] = {" 1Hz ", " 10Hz ", " 100Hz ", " 1kHz ", " 10kHz ", " 100kHz", " 1MHz "};
uint32_t step_sz[] = { 1, 10, 100, 1000, 10000, 100000, 1000000};
int step_index = 3;
volatile uint32_t radix = 1000; //start step size - change to suit
//------------EPROM memory related -----------------------------------------------------------
uint16_t max_memory_ch = 100; // each ch takes 10 bytes
struct allinfo {
uint32_t s_vfo;
uint32_t s_bfo;
uint16_t s_sb;
} Allinfo; // complete description of channel saved in mem
uint16_t eprom_base_addr = 0;
// Eprom content sequence: allinfo for vfoA, vfoB, mem1,2,3...
uint16_t address; // temp address used by fns
allinfo ch_info; // local copy
unsigned int memCh = 1; // memory channel number (1,2,3...100) now. Try names..??
//----------------------------------------------------------------------------------------------
bool Tx_timeout_mode = false;
unsigned long Tx_start_time = 0, rem_time = 0;
int diff;
int bnd_count, old_band;
int MAX_BANDS = 9;
volatile uint32_t F_MIN_T[9] = {100000UL, 3500000UL, 7000000UL, 10100000UL, 14000000UL, 18068000UL, 21000000UL, 24890000UL, 28000000UL};
volatile uint32_t F_MAX_T[9] = {75000000UL, 3800000UL, 7200000UL, 10150000UL, 14350000UL, 18168000UL, 21450000UL, 24990000UL, 29700000UL};
String B_NAME_T[] = {" VFO", " 80m", " 40m", " 30m", " 20m", " 17m", " 15m", " 12m", " 10m" };
volatile uint32_t VFO_T[9] = {9500000UL, 3670000UL, 7100000UL, 10120000UL, 14200000UL, 18105000UL, 21200000UL, 24925000UL, 28500000UL};
int band_cntrl[] = {23, 24, 25, 26, 27, 28, 29, 30, 31}; // pins for controlling BPF and LPF corresponding to each band
unsigned long F_MIN, F_MAX;
uint8_t magic_no = 01; // used for checking the initialization of eprom or to reinitialize change this no.
uint16_t xpos, ypos; //screen coordinates
uint16_t identifier; // TFT identifier : can be found from the example programs in the TFT library
int wd; //= tft.width();
int ht; //= tft.height();
int displ_rotn = 1; // 0 - normal, 1 - 90deg rotn (land scape), 2 - reverse, 3-rev LS ** if the touch buttons do not match try changing here
// individual button x,y coordinates, height and width, some common params,
int buttonht, buttonwd, smwd, smx, smy, smht, firstrowy, vfox, vfoy, vfowd, vfoht;
int memx, memy, memwd, memht, txrx, txry, txrwd, txrht, frqx, frqy, frqwd, frqht;
int vfoABMx, vfoABMy, frq2x1, frq2x2, frq2y, bandx, bandy, bandwd, bandht;
int stpx, stpy, stpwd, stpht, sbx, sby, sbwd, sbht, vmx, vmy, vmwd, vmht, bfox, bfoy, bfowd, bfoht;
int svx, svy, svwd, svht, f1x, f1y, f1wd, f1ht, f2x, f2y, f2wd, f2ht, f3x, f3y, f3wd, f3ht, f4x, f4y, f4wd, f4ht;
int botx, boty, botwd, botht;
int roundness; // box edge roundness
int spacing; // between buttons on same row
//-------------------- S Meter -------------------------------------------------------------------------
unsigned int Sval, Sens, Ssamp = 0; // s meter related
unsigned long Savg;
/**************************************/
/* Interrupt service routine for */
/* encoder frequency change */
/**************************************/
//void myISRRot()
ISR(PCINT2_vect)
{
unsigned char result = r.process();
if (result && !txstatus) // lock freq during transmit
{
if (result == DIR_CW)
vfo += radix;
else if (result == DIR_CCW)
vfo -= radix;
changed_f = 1;
}
}
void setup()
{
// Serial.begin(57600); // for debugging
#ifdef MCUF0x154
identifier = 0x154; // identify display driver chip (known from mcufriend test progs)
// spf display
TS_LEFT = 950; //**? how to find these points automagically
TS_RT = 120;
TS_TOP = 920;
TS_BOT = 120;
YP = A1; // must be an analog pin, use "An" notation!
XM = A2; // must be an analog pin, use "An" notation!
YM = 7; // can be a digital pin
XP = 6; // can be a digital pin
#endif
#ifdef elegoo923
identifier = 0x9341; // Joe's 2.8 DISPLAYblueg5/5elegoo
// Joes display
TS_LEFT = 74; // 923elegoo testing------74---- Tested by Joe Basque
TS_RT = 906;// 117-------------------906 --------
TS_TOP = 117 ; //117
TS_BOT = 923;//923
YP = A3; // must be an analog pin, use "An" notation!
XM = A2; // must be an analog pin, use "An" notation!
YM = 9; // can be a digital pin
XP = 8; // can be a digital pin
#endif
ts = TouchScreen(XP, YP, XM, YM, 300);
tft.begin(identifier); // setup to use driver
wd = tft.width();
ht = tft.height();
tft.setRotation(displ_rotn); // LS
if (displ_rotn == 1 || displ_rotn == 3) // exchange the width and height
{
int temp = wd; wd = ht; ht = temp;
}
dispPos();
#ifdef IF_12MHZ
bfo = 11997000UL; // for 12MHz xtal filter as in BITx40 HFSIG
bfo_USB = 11994000UL;
bfo_LSB = 11996000UL;
#endif
#ifdef IF_10MHZ // eg in our homebrewed Bitx
bfo = 9996000UL; // should be selected based on txcvr
bfo_USB = 9994000UL;
bfo_LSB = 9996000UL; // all bfos are tunable and saved on EEPROM
#endif
Wire.begin(); // for si5351
// welcome_screen();
setup_vfo_screen(); // create main VFO screen
if (EEPROM.read(eprom_base_addr) != magic_no)
init_eprom(); // if blank eeprom or changed/new magic_no for reinit
read_eprom(); // get infos of VFO A & B (and 1st memory channel only??)
vfo = vfo_A; // then display and use VFO A
vfo_A_sel = 1;
bfo = bfo_A;
sideband = sb_A;
digitalWrite(PTT_Output, LOW); // Init in Rx mode
//si5351.reset(); //
//Initialise si5351
// si5351.set_correction(00); //. There is a calibration sketch in File/Examples/si5351Arduino-Jason; was 140
//where you can determine the correction by using the serial monitor.
//initialize the Si5351
si5351.init(SI5351_CRYSTAL_LOAD_8PF, 0, si5351correction); //If you're using a 27Mhz crystal, put in 27000000 instead of 0
// 0 is the default crystal frequency of 25Mhz. ** si5351correction=710000UL for SPF's system ??
si5351.set_pll(SI5351_PLL_FIXED, SI5351_PLLA);
si5351.drive_strength(SI5351_CLK0, SI5351_DRIVE_2MA); // this is 11dBm // you can set this to 2MA, 4MA, 6MA or 8MA
// si5351.drive_strength(SI5351_CLK1, SI5351_DRIVE_4MA); //be careful though - measure into 50ohms
//si5351.drive_strength(SI5351_CLK2,SI5351_DRIVE_6MA); //
// Set CLK0 to output the starting "vfo" frequency as set above by vfo = ?
if (sideband == LSB)
bfo = bfo_LSB;
else
bfo = bfo_USB;
set_vfo();
// Set CLK2 to output bfo frequency
#ifndef FIXED_BFO
set_bfo();
#endif
Tx_timeout = Tx_timeout * 1000; //in ms
pinMode(ENCODER_BTN, INPUT_PULLUP); // ? pushbutton setup
pinMode(BandSelect, INPUT_PULLUP); // band pushbutton setup
pinMode(SideBandSelect, INPUT_PULLUP); //sideband pushbutton setup
pinMode(VFO, INPUT_PULLUP); //VFO pushbutton setup
pinMode(VtoMEM, INPUT_PULLUP); //VtoM pushbutton setup
pinMode(STEP, INPUT_PULLUP); //Step pushbutton setup
pinMode(PTT_Input, INPUT_PULLUP); // PTT Button toggle type
pinMode(PTT_Output, OUTPUT); // PTT output pin
for (int i = 0; i <= MAX_BANDS; i++) // all band control pins init & OFF
{
pinMode(band_cntrl[i], OUTPUT);
digitalWrite(band_cntrl[i], LOW);
}
/*
//Mega2560
// external interrupt int.0 int.1 int.2 int.3 int.4 int.5
// pin 2 3 21 20 19 18
// interrupt # 0, pin 2
//attachInterrupt(4, myISRRot, CHANGE); // Also LOW, RISING, FALLING
attachInterrupt(digitalPinToInterrupt(ENCODER_A), myISRRot, CHANGE); // tried on D18
attachInterrupt(digitalPinToInterrupt(ENCODER_B), myISRRot, CHANGE); // tried on D19
/*
/*
// PCMSK2 |= (1 << PCINT18) | (1 << PCINT19); // uno
PCICR |= (1 << PCIE2); // Enable pin change interrupt for the encoder
PCMSK2 |= (1 << PCINT2) | (1 << PCINT3); // MEGA interrupt pins mapped to D18 19?? */
PCICR |= (1 << PCIE2); // Enable pin change interrupt for the encoder
PCMSK2 |= (1 << PCINT21) | (1 << PCINT22); // MEGA interrupt pins mapped to A14 A13
sei(); // start interrupts
display_frequency(); // Update the local display at power on
display_vfo();
display_band(); // with values
display_step();
display_sideband();
display_mem();
display_bfo();
} // end of setup() //
//--------------------------------------
void loop()
{
// Update the display if the frequency changed
if (changed_f)
{
set_vfo();
display_frequency();
set_band();
display_band();
display_sideband();
save_frequency();
changed_f = 0;
return;
}
if (Tx_timeout_mode)
{
rem_time = millis() - Tx_start_time; // remaining time
if (txstatus)
{
if ( rem_time >= Tx_timeout)
{
digitalWrite(PTT_Output, LOW);
displ_rx();
txstatus = false;
}
else
{
tft.setCursor(txrx + 45, txry + 5);
tft.setTextSize(2);
tft.setTextColor(WHITE, RED);
diff = (Tx_timeout - rem_time) / 1000 ;
if (diff <= 9)
tft.print(" ");
tft.print(diff);
}
}
}
//-----------------------------------
// External button controls
//##### Cycle through VFOs
{ if (digitalRead(VFO) == LOW )
if (get_button(VFO))
vfo_sel();
}
//#### Toggle PTT button
if (!active_PTT_in) // normal PTT goes to ground on press for short time
{ if (digitalRead(PTT_Input) == LOW )
if (get_button(PTT_Input))
rx_tx_ptt();
}
else // it is an active PTT which goes high during QSO
{
if (digitalRead(PTT_Input) == HIGH && !txstatus)
{
delay(50);
rx_tx_ptt();
}
else
{
if (digitalRead(PTT_Input) == LOW && txstatus)
{
delay(50);
rx_tx_ptt();
}
}
}
//##### Band Select
{ if (digitalRead(BandSelect) == LOW )
if (get_button(BandSelect))
band_incr();
}
//##### Step Size
{ if (digitalRead(STEP) == LOW )
if (get_button(STEP))
step_decr();
}
//####
{ if (digitalRead(SideBandSelect) == LOW )
if (get_button(SideBandSelect))
sideband_chg();
}
//####
{ if (digitalRead(VtoMEM) == LOW )
if (get_button(VtoMEM))
vfo_to_mem();
}
//----------------------------------------------
//$$$$ for Touch Screen input control
tp = ts.getPoint();
pinMode(XM, OUTPUT);
pinMode(YP, OUTPUT);
pinMode(XP, OUTPUT);
pinMode(YM, OUTPUT);
delay(ts_delay); // delay between two touches to reduce sensitivity
if (tp.z > MINPRESSURE && tp.z < MAXPRESSURE)
{
#ifdef MCUF0x154
xpos = map(tp.x, TS_LEFT, TS_RT, 0, tft.width());
ypos = map(tp.y, TS_TOP, TS_BOT, 0, tft.height());
#endif
#ifdef elegoo923
xpos = map(tp.y, TS_LEFT, TS_RT, 0, tft.width());
ypos = map(tp.x, TS_TOP, TS_BOT, 0, tft.height());
#endif
if (ypos > firstrowy && ypos < firstrowy + buttonht) // first row of buttons (orig 5,42)
{
// VFO Button: cycle VFO A/B/M in sequence when VFO button is touched
if (xpos > vfox && xpos < vfox + vfowd ) // change VFO (orig 20,95)
vfo_sel();
// MEM Ch change Button
// Left half button decreases channel no
else if (xpos > memx && xpos < memx + buttonwd - 2 ) // decrease channel ,(110,175)
mem_decr(); // decrease memory channel number
// right half buttton increases ch no
else if (xpos > memx + buttonwd + 2 && xpos < memx + 2 * buttonwd ) // increase channel (176,245)
mem_incr(); // increase mem ch no
// Rx/Tx PTT touch button or PTT_Input (D16)
else if (xpos > txrx && xpos < txrx + txrwd - 2 ) // toggle between Rx & Tx, PTT_Output (D17) goes Hi on Tx
{ rx_tx_ptt();
delay(100);
}
return;
} // First row end
//$$$$$ Freq Change Second Row touch Button
if (ypos > frqy && ypos < frqy + frqht && !txstatus) //(45,85) lock freq change during transmit
{
if (xpos > frqx && xpos < (frqx + frqwd / 2) - 2 ) // Left half button decreases frq by step size (50,180)
{
vfo = vfo - radix;
changed_f = 1;
}
else if (xpos > (frqx + frqwd / 2) + 2 && xpos < frqx + frqwd && !txstatus) // Right half button increases freq by step size (185,310), lock freq change during transmit
{
vfo = vfo + radix;
changed_f = 1;
}
save_frequency(); // added 7/7/17
return;
} // Freq Button/ Second Row end
//$$$$ Third Row Band Change Button
if (ypos > bandy && ypos < bandy + bandht) //(113,150)
{
if (xpos > bandx && xpos < (bandx + bandwd / 2) - 2 ) // Left half button decreases band(20,65)
band_decr();
else if (xpos > (bandx + bandwd / 2) + 2 && xpos < bandx + bandwd ) // Right half button increases band (67,115)
band_incr();
// $$$$ Third Row Step Size change Button
// left half of step button decreases step size
else if (xpos > stpx && xpos < (stpx + stpwd / 2) - 2 ) //(114,175)
step_decr();
// right half of step button increases step size
else if (xpos > (stpx + stpwd / 2) + 2 && xpos < stpx + stpwd ) // (177,238)
step_incr();
///$$$$$ Third Row side band flip flop between LSB & USB (others may be added if hardware permits)
else if (xpos > sbx && xpos < sbx + sbwd ) // (245,310)
sideband_chg();
return;
} // Third row end
if (ypos > vmy && ypos < vmy + vmht) // (152,189) fourth row
{
//$$$$$ Fourth Row VFO < > Mem switch nothing saved on EEPROM unless SAVE button pressed
if (xpos > vmx && xpos < (vmx + vmwd / 2) - 2 ) //left half VFO -> MEM (20,65)
// currently selected VFO stored on currently selected mem ch (not in EEPROM which is by SAVE button)
vfo_to_mem();
else if (xpos > (vmx + vmwd / 2) + 2 && xpos < vmx + vmwd ) //right half VFO <- MEM (66,109)
mem_to_vfo();
#ifndef FIXED_BFO
// $$$$$ Fourth Row bfo freq adjust
// left half button decreases bfo freq
else if (xpos > bfox && xpos < (bfox + bfowd / 2) - 2 ) // decrease freq
bfo_decr();
// right half button increases bfo freq
else if (xpos > (bfox + bfowd / 2) + 2 && xpos < bfox + bfowd ) // increase freq (175,235)
bfo_incr();
#endif
// Fourth Row SAVE Button
else if (xpos > svx && xpos < svx + svwd ) // Save "current" Vfo/Mem on eeprom (245,310)
save();
} // Fourth Row end
//--------------Fifth Row
if (ypos > f1y && ypos < f1y + f1ht) // fifth row
{
if (xpos > f1x && xpos < f1x + f1wd) // Tx time out button RED / Green, Mode activated, timer starts on PTT
{
Tx_timeout_mode = !Tx_timeout_mode; // toggle mode on rpeated touch
if (Tx_timeout_mode) // button red
{
tft.drawRoundRect(f1x, f1y, f1wd, f1ht, roundness, WHITE); // F1 button outline TxTimeOut
tft.fillRoundRect(f1x + 2, f1y + 2, f1wd - 4, f1ht - 4, roundness - 4, RED); //F1
tft.setTextSize(2);
tft.setTextColor(WHITE);
tft.setCursor(f1x + 5, f1y + 8);
tft.print("TxTmO");
Tx_start_time = 0; // timer acually starts by PTT in rx_tx_ptt() function
}
else // button green when not in Tx timeout mode
{
tft.drawRoundRect(f1x, f1y, f1wd, f1ht, roundness, WHITE); // F1 button outline TxTimeOut
tft.fillRoundRect(f1x + 2, f1y + 2, f1wd - 4, f1ht - 4, roundness - 4, GREEN); //F1
tft.setTextSize(2);
tft.setTextColor(BLUE);
tft.setCursor(f1x + 5, f1y + 8);
tft.print("TxTmO");
}
}
}
}
//=====================
//$$$$ S Meter display Take average and display after Ssamp no of samples
// Logic not perfect as of v2.4
Ssamp++; // sample no
Sval = analogRead(SENSOR);
Savg = (Savg + Sval );
if (Ssamp >= 10) // calc & display every 10 samples
{
Savg = Savg / Ssamp;
// Serial.println(Savg);
{
Sens = map(Savg, 0, 1023, 0, botwd - 50);
tft.fillRect(botx + 3, boty + 3, botwd - 8, botht - 5, BLACK);
if (Savg < 180) { // lower scale upside down ///180 is random now should dc test
tft.fillRect(botx + 3, boty + 3, Sens - 4, botht - 5, GREEN);
}
if (Savg > 180) { // middle scale
tft.fillRect(botx + 3, boty + 3, Sens - 4, botht - 5, MAGENTA);
if (Savg > 500) { // upper scale
tft.fillRect(botx + 3, boty + 3, Sens - 4, botht - 5, RED);
}
}
}
Ssamp = 0;
Savg = 0;
}
} // end of loop()