A simple oscilloscope using Adafruit 2.8" TFT with touch. Runs on FRDM-KL25Z, FRDM-K22F, FRDM-K64F, NUCLEO-F411RE. 2 channel analog inputs with 4 trigger modes and time division.

Dependencies:   SPI_STMPE610 UniGraphic mbed vt100

My first attempt of implementing an oscilloscope using FRDM-KL25Z and Adafruit 2.8" TFT with touch.

FRDM-KL25Z と Adafruit 2.8" TFT with touch を使用して作ってみた最初のオシロスコープです。

On 25-Sep-2017, wrong calculation of trigger pos/val fixed.
On 25-Nov-2015, FRDM-K64F and NUCLEO-F411RE platforms were added.
On 26-Nov-2015, FRDM-K22F is added (tested).
Note: Now ch2 is A2 instead of A1!

25-Sep-2017, トリガー値と位置の計算の誤りを修正しました。
25-Nov-2015, FRDM-K64F と NUCLEO-F411RE でも動くようになりました。
26-Nov-2015, FRDM-K22F でも動作確認が出来ました。 ※一身上の都合で、アナログ入力の ch2 は A1 から A2 に変更しましたので、ご注意ください。m(_ _)m

/media/uploads/Rhyme/oscillo_top.jpg

This supports two analog inputs A0 for channel 1 and A2 for channel 2
and four trigger modes (NONE, RISE, FALL, LEVEL),
time division is 30us to 20ms per pixel which will make 300us/div to 200.0ms/div (as 10 pixels per div)

A0と A2 のアナログ2入力にて、
4種類のトリガーモード(NONE: フリーラン RISE: 立ち上がりエッジ、FALL: 立下りエッジ、LEVEL: レベル) 。
サンプリングは30us から 20ms, チャートの1メモリが10ピクセルなので、300us/dev から 200.0ms/div となっています。

The analog signals and gnd was picked at the pins in the picture above.
Note: now you need to pick A0 and A2 instead of A0 and A1.

信号は上記の写真のように、Adafruit のピンからつまみました。
変更により、A0とA2が入力となります。

/media/uploads/Rhyme/freerunmode.jpg

When powered on or reset, the program starts in Trigger Mode = NONE (Free Run Mode)

電源投入、リセット後 プログラムはトリガーモード NONE (フリーランモード) で起動します。

To change trigger mode and/or time division, press run/stop button.

トリガーモードを変えたり、サンプリング時間を変えるのには run/stop ボタンを押してください。

Each time you push Trig button, the trigger mode changes
NONE -> RISE -> FALL -> LEVEL ( -> NONE).

トリガーボタンを押すたびにトリガーモードは
NONE(フリーラン) -> RISE (立ち上がりエッジ) -> FALL (立下りエッジ) -> LEVEL (レベル)
と変化します。

When trigger mode is not NONE,
to specify the trigger position, level and channel, push inside the wave frame.
Then green trigger marks will be shown and value of trigger position and voltage will be printed.

トリガーモードが NONE でないときに、チャネルの枠内をタッチしますと、
その位置がトリガーのポジション、レベル、チャネルになります。 そして、緑色のトリガーマークが表示され、下部にはトリガーの具体的なポジションとボルテージが表示されます。

/media/uploads/Rhyme/usage_screen1.jpg

To change time division push "1/2" to Zoom Out (sampling interval will be bigger) or
"x2" to Zoom In (Sampling interval will be smaller).

サンプリングタイムを変更するのには
"1/2" ズームアウト (サンプリング間隔が長くなります) か
"x2" ズームイン (サンプリング間隔が短くなります。) を押してください。

/media/uploads/Rhyme/helps.jpg

On 7-Mar-2015 updated to UniGraphic library version!

2015年3月7日 UniGraphic ライブラリ使用版にアップデートしました。

/media/uploads/Rhyme/frdm-kl25z-ss.jpg FRDM-KL25Z
/media/uploads/Rhyme/frdm-k64f-ss.jpg FRDM-K64F
/media/uploads/Rhyme/nucleo-f411re-ss.jpg NUCLEO-F411RE

Committer:
Rhyme
Date:
Sat Jan 10 15:08:38 2015 +0000
Revision:
0:2b9a6c5fcd52
Child:
2:4b9260139892
commit before publish

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Rhyme 0:2b9a6c5fcd52 1 /** mbed oscilloscope my implementation of a oscillo scope
Rhyme 0:2b9a6c5fcd52 2 * Copyright (c) 2014, 2015 Motoo Tanaka @ Design Methodology Lab
Rhyme 0:2b9a6c5fcd52 3 *
Rhyme 0:2b9a6c5fcd52 4 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Rhyme 0:2b9a6c5fcd52 5 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Rhyme 0:2b9a6c5fcd52 6 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Rhyme 0:2b9a6c5fcd52 7 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Rhyme 0:2b9a6c5fcd52 8 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Rhyme 0:2b9a6c5fcd52 9 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
Rhyme 0:2b9a6c5fcd52 10 * THE SOFTWARE.
Rhyme 0:2b9a6c5fcd52 11 */
Rhyme 0:2b9a6c5fcd52 12 #include "mbed.h"
Rhyme 0:2b9a6c5fcd52 13 #include "SPI_TFT_ILI9341.h"
Rhyme 0:2b9a6c5fcd52 14 #include "SPI_STMPE610.h"
Rhyme 0:2b9a6c5fcd52 15 #include "Arial12x12.h"
Rhyme 0:2b9a6c5fcd52 16 #include "Arial24x23.h"
Rhyme 0:2b9a6c5fcd52 17 #include "Arial28x28.h"
Rhyme 0:2b9a6c5fcd52 18 #include "font_big.h"
Rhyme 0:2b9a6c5fcd52 19 #include "vt100.h"
Rhyme 0:2b9a6c5fcd52 20 #include "TFTMenu.h"
Rhyme 0:2b9a6c5fcd52 21 #include "menu.h"
Rhyme 0:2b9a6c5fcd52 22 #include "trig.h"
Rhyme 0:2b9a6c5fcd52 23 #include "view.h"
Rhyme 0:2b9a6c5fcd52 24 #include "main.h"
Rhyme 0:2b9a6c5fcd52 25
Rhyme 0:2b9a6c5fcd52 26 vt100 tty ;
Rhyme 0:2b9a6c5fcd52 27 AnalogIn *ach[NUM_MAX_ANALOG_CH] ;
Rhyme 0:2b9a6c5fcd52 28 Ticker timer ;
Rhyme 0:2b9a6c5fcd52 29
Rhyme 0:2b9a6c5fcd52 30 DigitalOut backlight(PTA12) ;
Rhyme 0:2b9a6c5fcd52 31 SPI_TFT_ILI9341 TFT(PIN_MOSI, PIN_MISO, PIN_SCLK, PIN_CS_TFT, PIN_BL_TFT, PIN_DC_TFT) ;
Rhyme 0:2b9a6c5fcd52 32 SPI_STMPE610 TSC(PIN_MOSI, PIN_MISO, PIN_SCLK, PIN_CS_TSC) ;
Rhyme 0:2b9a6c5fcd52 33 TFTMenuItem *menu[NUM_MAX_MENU] ;
Rhyme 0:2b9a6c5fcd52 34 int numMenu = 0 ;
Rhyme 0:2b9a6c5fcd52 35
Rhyme 0:2b9a6c5fcd52 36 float vref = 3.28 ; // input range 0 - 3.3V
Rhyme 0:2b9a6c5fcd52 37 uint16_t udata[2][NUM_MAX_ANALOG_CH][CHART_LEN] ; // data storage ;
Rhyme 0:2b9a6c5fcd52 38 uint16_t bor[2] = {0, 0} ; // begin of ring buffer
Rhyme 0:2b9a6c5fcd52 39 int data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 40 int numAnalogIn = 2 ;
Rhyme 0:2b9a6c5fcd52 41 int memLength = CHART_LEN ;
Rhyme 0:2b9a6c5fcd52 42 int us_interval = MIN_INTERVAL ; // 20us = 50KHz
Rhyme 0:2b9a6c5fcd52 43 bool frame_full = false ;
Rhyme 0:2b9a6c5fcd52 44 int page = 0 ; //
Rhyme 0:2b9a6c5fcd52 45 int prev_page = 0 ;
Rhyme 0:2b9a6c5fcd52 46 int mode = MODE_RUN ;
Rhyme 0:2b9a6c5fcd52 47
Rhyme 0:2b9a6c5fcd52 48 void sampleAD(void) ;
Rhyme 0:2b9a6c5fcd52 49 void drawMenu(void) ;
Rhyme 0:2b9a6c5fcd52 50 // void eraseGraphFrames(void) ;
Rhyme 0:2b9a6c5fcd52 51
Rhyme 0:2b9a6c5fcd52 52 /**
Rhyme 0:2b9a6c5fcd52 53 * u2v unsigned int data value to voltage conversion
Rhyme 0:2b9a6c5fcd52 54 */
Rhyme 0:2b9a6c5fcd52 55 float u2v(uint16_t uvalue)
Rhyme 0:2b9a6c5fcd52 56 {
Rhyme 0:2b9a6c5fcd52 57 return( vref * (float)uvalue / 65535.0 ) ;
Rhyme 0:2b9a6c5fcd52 58 }
Rhyme 0:2b9a6c5fcd52 59
Rhyme 0:2b9a6c5fcd52 60 /**
Rhyme 0:2b9a6c5fcd52 61 * v2u voltage to unsigned int data conversion
Rhyme 0:2b9a6c5fcd52 62 */
Rhyme 0:2b9a6c5fcd52 63 uint16_t v2u(float voltage)
Rhyme 0:2b9a6c5fcd52 64 {
Rhyme 0:2b9a6c5fcd52 65 return(0xFFFF * voltage / vref) ;
Rhyme 0:2b9a6c5fcd52 66 }
Rhyme 0:2b9a6c5fcd52 67
Rhyme 0:2b9a6c5fcd52 68 /**
Rhyme 0:2b9a6c5fcd52 69 * u2f unsigned int to float (0 - 1.0) conversion
Rhyme 0:2b9a6c5fcd52 70 */
Rhyme 0:2b9a6c5fcd52 71 float u2f(uint16_t value)
Rhyme 0:2b9a6c5fcd52 72 {
Rhyme 0:2b9a6c5fcd52 73 return( (float)value / 65535.0 ) ;
Rhyme 0:2b9a6c5fcd52 74 }
Rhyme 0:2b9a6c5fcd52 75
Rhyme 0:2b9a6c5fcd52 76 void initADC(void)
Rhyme 0:2b9a6c5fcd52 77 {
Rhyme 0:2b9a6c5fcd52 78 if (numAnalogIn > 0) {
Rhyme 0:2b9a6c5fcd52 79 ach[0] = new AnalogIn(PTB0) ;
Rhyme 0:2b9a6c5fcd52 80 }
Rhyme 0:2b9a6c5fcd52 81 if (numAnalogIn > 1) {
Rhyme 0:2b9a6c5fcd52 82 ach[1] = new AnalogIn(PTB1) ;
Rhyme 0:2b9a6c5fcd52 83 }
Rhyme 0:2b9a6c5fcd52 84
Rhyme 0:2b9a6c5fcd52 85 ADC0->CFG1 = ADC0->CFG1 & (
Rhyme 0:2b9a6c5fcd52 86 ~(
Rhyme 0:2b9a6c5fcd52 87 0x80 // LDLPC = 0 ; no low-power mode
Rhyme 0:2b9a6c5fcd52 88 | 0x60 // ADIV = 1
Rhyme 0:2b9a6c5fcd52 89 | 0x10 // Sample time short
Rhyme 0:2b9a6c5fcd52 90 | 0x03 // input clock = BUS CLK
Rhyme 0:2b9a6c5fcd52 91 )
Rhyme 0:2b9a6c5fcd52 92 ) ; // clkdiv <= 1
Rhyme 0:2b9a6c5fcd52 93 ADC0->CFG2 = ADC0->CFG2
Rhyme 0:2b9a6c5fcd52 94 | 0x03 ; // Logsample Time 11 = 2 extra ADCK
Rhyme 0:2b9a6c5fcd52 95 ADC0->SC3 = ADC0->SC3
Rhyme 0:2b9a6c5fcd52 96 & (~(0x03)) ; // hardware avarage off
Rhyme 0:2b9a6c5fcd52 97 }
Rhyme 0:2b9a6c5fcd52 98
Rhyme 0:2b9a6c5fcd52 99 void envChanged(void)
Rhyme 0:2b9a6c5fcd52 100 {
Rhyme 0:2b9a6c5fcd52 101 timer.detach() ;
Rhyme 0:2b9a6c5fcd52 102
Rhyme 0:2b9a6c5fcd52 103 eraseGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 104 drawGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 105
Rhyme 0:2b9a6c5fcd52 106 data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 107 page = 0 ;
Rhyme 0:2b9a6c5fcd52 108 prev_page = 0 ;
Rhyme 0:2b9a6c5fcd52 109 frame_full = false ;
Rhyme 0:2b9a6c5fcd52 110 if (trig_mode == TRIG_MODE_NONE) {
Rhyme 0:2b9a6c5fcd52 111 sampling_status = ST_TRIG_HIT ;
Rhyme 0:2b9a6c5fcd52 112 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 113 } else {
Rhyme 0:2b9a6c5fcd52 114 sampling_status = ST_PRE_TRIG ;
Rhyme 0:2b9a6c5fcd52 115 }
Rhyme 0:2b9a6c5fcd52 116 /*
Rhyme 0:2b9a6c5fcd52 117 if (mode == MODE_RUN) {
Rhyme 0:2b9a6c5fcd52 118 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 119 }
Rhyme 0:2b9a6c5fcd52 120 */
Rhyme 0:2b9a6c5fcd52 121 }
Rhyme 0:2b9a6c5fcd52 122
Rhyme 0:2b9a6c5fcd52 123 bool checkTrigger(void)
Rhyme 0:2b9a6c5fcd52 124 {
Rhyme 0:2b9a6c5fcd52 125 bool result = false ;
Rhyme 0:2b9a6c5fcd52 126 int prev_index ;
Rhyme 0:2b9a6c5fcd52 127 uint16_t current, prev ;
Rhyme 0:2b9a6c5fcd52 128 if (data_index > 0) {
Rhyme 0:2b9a6c5fcd52 129 prev_index = data_index - 1 ;
Rhyme 0:2b9a6c5fcd52 130 } else {
Rhyme 0:2b9a6c5fcd52 131 prev_index = memLength - 1 ; // memLength - 1 ;
Rhyme 0:2b9a6c5fcd52 132 }
Rhyme 0:2b9a6c5fcd52 133 current = udata[page][trig_ch][data_index] ;
Rhyme 0:2b9a6c5fcd52 134 prev = udata[page][trig_ch][prev_index] ;
Rhyme 0:2b9a6c5fcd52 135
Rhyme 0:2b9a6c5fcd52 136 switch(trig_mode) {
Rhyme 0:2b9a6c5fcd52 137 case TRIG_MODE_NONE: // no trigger, return true at the beggining
Rhyme 0:2b9a6c5fcd52 138 trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 139 result = true ;
Rhyme 0:2b9a6c5fcd52 140 break ;
Rhyme 0:2b9a6c5fcd52 141 case TRIG_MODE_RISE:
Rhyme 0:2b9a6c5fcd52 142 if ((prev < utrig_level)&&(utrig_level <= current)) {
Rhyme 0:2b9a6c5fcd52 143 result = true ;
Rhyme 0:2b9a6c5fcd52 144 }
Rhyme 0:2b9a6c5fcd52 145 break ;
Rhyme 0:2b9a6c5fcd52 146 case TRIG_MODE_FALL:
Rhyme 0:2b9a6c5fcd52 147 if ((prev > utrig_level)&&(utrig_level >= current)) {
Rhyme 0:2b9a6c5fcd52 148 result = true ;
Rhyme 0:2b9a6c5fcd52 149 }
Rhyme 0:2b9a6c5fcd52 150 break ;
Rhyme 0:2b9a6c5fcd52 151 case TRIG_MODE_LEVEL:
Rhyme 0:2b9a6c5fcd52 152 if (current > trig_level_margin) {
Rhyme 0:2b9a6c5fcd52 153 if (((current + trig_level_margin) >= utrig_level)&&(utrig_level >= (current - trig_level_margin))) {
Rhyme 0:2b9a6c5fcd52 154 result = true ;
Rhyme 0:2b9a6c5fcd52 155 }
Rhyme 0:2b9a6c5fcd52 156 } else {
Rhyme 0:2b9a6c5fcd52 157 if ((current + trig_level_margin) >= utrig_level) {
Rhyme 0:2b9a6c5fcd52 158 result = true ;
Rhyme 0:2b9a6c5fcd52 159 }
Rhyme 0:2b9a6c5fcd52 160 }
Rhyme 0:2b9a6c5fcd52 161 break ;
Rhyme 0:2b9a6c5fcd52 162 default:
Rhyme 0:2b9a6c5fcd52 163 printf("Error: Unknown trigger mode %d\n", trig_mode) ;
Rhyme 0:2b9a6c5fcd52 164 break ;
Rhyme 0:2b9a6c5fcd52 165 }
Rhyme 0:2b9a6c5fcd52 166 return( result ) ;
Rhyme 0:2b9a6c5fcd52 167 }
Rhyme 0:2b9a6c5fcd52 168
Rhyme 0:2b9a6c5fcd52 169 void sampleAD(void)
Rhyme 0:2b9a6c5fcd52 170 {
Rhyme 0:2b9a6c5fcd52 171 if (frame_full) {
Rhyme 0:2b9a6c5fcd52 172 return ;
Rhyme 0:2b9a6c5fcd52 173 }
Rhyme 0:2b9a6c5fcd52 174 // timer.detach() ;
Rhyme 0:2b9a6c5fcd52 175 for (int i = 0 ; i < numAnalogIn ; i++ ) {
Rhyme 0:2b9a6c5fcd52 176 udata[page][i][data_index] = ach[i]->read_u16() ;
Rhyme 0:2b9a6c5fcd52 177 }
Rhyme 0:2b9a6c5fcd52 178 // timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 179 switch(sampling_status) {
Rhyme 0:2b9a6c5fcd52 180 case ST_PRE_TRIG:
Rhyme 0:2b9a6c5fcd52 181 if (data_index >= trig_pos) {
Rhyme 0:2b9a6c5fcd52 182 sampling_status = ST_TRIG_WAIT ;
Rhyme 0:2b9a6c5fcd52 183 } else {
Rhyme 0:2b9a6c5fcd52 184 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 185 }
Rhyme 0:2b9a6c5fcd52 186 break ;
Rhyme 0:2b9a6c5fcd52 187 case ST_TRIG_WAIT:
Rhyme 0:2b9a6c5fcd52 188 if (checkTrigger()) {
Rhyme 0:2b9a6c5fcd52 189 trig_index = data_index ;
Rhyme 0:2b9a6c5fcd52 190 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 191 sampling_status = ST_TRIG_HIT ;
Rhyme 0:2b9a6c5fcd52 192 } else {
Rhyme 0:2b9a6c5fcd52 193 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 194 }
Rhyme 0:2b9a6c5fcd52 195 break ;
Rhyme 0:2b9a6c5fcd52 196 case ST_TRIG_HIT:
Rhyme 0:2b9a6c5fcd52 197 post_trig_index++ ;
Rhyme 0:2b9a6c5fcd52 198 if (post_trig_index >= post_trig_len) {
Rhyme 0:2b9a6c5fcd52 199 sampling_status = ST_BUF_FULL ;
Rhyme 0:2b9a6c5fcd52 200 frame_full = true ;
Rhyme 0:2b9a6c5fcd52 201 bor[page] = (memLength + trig_index - trig_pos) % memLength ;
Rhyme 0:2b9a6c5fcd52 202 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 203 data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 204 } else {
Rhyme 0:2b9a6c5fcd52 205 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 206 }
Rhyme 0:2b9a6c5fcd52 207 break ;
Rhyme 0:2b9a6c5fcd52 208 case ST_BUF_FULL:
Rhyme 0:2b9a6c5fcd52 209 printf("mode = ST_BUF_FULL\n\r") ;
Rhyme 0:2b9a6c5fcd52 210 break ;
Rhyme 0:2b9a6c5fcd52 211 default:
Rhyme 0:2b9a6c5fcd52 212 printf("unknown sample status %d\n", sampling_status) ;
Rhyme 0:2b9a6c5fcd52 213 break ;
Rhyme 0:2b9a6c5fcd52 214 }
Rhyme 0:2b9a6c5fcd52 215 }
Rhyme 0:2b9a6c5fcd52 216
Rhyme 0:2b9a6c5fcd52 217
Rhyme 0:2b9a6c5fcd52 218 bool doTrigValue(int x, int y)
Rhyme 0:2b9a6c5fcd52 219 {
Rhyme 0:2b9a6c5fcd52 220 int i, y_offset ;
Rhyme 0:2b9a6c5fcd52 221 bool result = false ;
Rhyme 0:2b9a6c5fcd52 222 for (i = 0 ; i < numAnalogIn ; i++ ) {
Rhyme 0:2b9a6c5fcd52 223 if (inChFrame(i, x, y)) {
Rhyme 0:2b9a6c5fcd52 224 result = true ;
Rhyme 0:2b9a6c5fcd52 225 trig_ch = i ;
Rhyme 0:2b9a6c5fcd52 226 trig_pos = x - left_margin;
Rhyme 0:2b9a6c5fcd52 227 post_trig_len = memLength - trig_pos ;
Rhyme 0:2b9a6c5fcd52 228 y_offset = head_h + (pane_h + 5) * i + 1;
Rhyme 0:2b9a6c5fcd52 229 trig_level = vref *(1 - ((float)(y - y_offset) / (float)(pane_h - 2))) ;
Rhyme 0:2b9a6c5fcd52 230 if (trig_level > vref) {
Rhyme 0:2b9a6c5fcd52 231 trig_level = vref ;
Rhyme 0:2b9a6c5fcd52 232 } else if (trig_level < 0.0) {
Rhyme 0:2b9a6c5fcd52 233 trig_level = 0.0 ;
Rhyme 0:2b9a6c5fcd52 234 }
Rhyme 0:2b9a6c5fcd52 235 utrig_level = v2u( trig_level ) ;
Rhyme 0:2b9a6c5fcd52 236 break ;
Rhyme 0:2b9a6c5fcd52 237 }
Rhyme 0:2b9a6c5fcd52 238 }
Rhyme 0:2b9a6c5fcd52 239 return( result ) ;
Rhyme 0:2b9a6c5fcd52 240 }
Rhyme 0:2b9a6c5fcd52 241
Rhyme 0:2b9a6c5fcd52 242 void hello()
Rhyme 0:2b9a6c5fcd52 243 {
Rhyme 0:2b9a6c5fcd52 244 printf("=== simple oscilloscope ===\n\r") ;
Rhyme 0:2b9a6c5fcd52 245 printf("built: %s\n\r",__DATE__) ;
Rhyme 0:2b9a6c5fcd52 246 }
Rhyme 0:2b9a6c5fcd52 247
Rhyme 0:2b9a6c5fcd52 248 int main()
Rhyme 0:2b9a6c5fcd52 249 {
Rhyme 0:2b9a6c5fcd52 250 int touched ;
Rhyme 0:2b9a6c5fcd52 251 uint16_t x, y ;
Rhyme 0:2b9a6c5fcd52 252 bool result ;
Rhyme 0:2b9a6c5fcd52 253 tty.cls() ;
Rhyme 0:2b9a6c5fcd52 254 backlight = 0 ;
Rhyme 0:2b9a6c5fcd52 255 initTFT() ;
Rhyme 0:2b9a6c5fcd52 256 initADC() ;
Rhyme 0:2b9a6c5fcd52 257 initMenu() ;
Rhyme 0:2b9a6c5fcd52 258
Rhyme 0:2b9a6c5fcd52 259 us_interval = MIN_INTERVAL ;
Rhyme 0:2b9a6c5fcd52 260
Rhyme 0:2b9a6c5fcd52 261 drawGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 262 drawMenu() ;
Rhyme 0:2b9a6c5fcd52 263
Rhyme 0:2b9a6c5fcd52 264 backlight = 1 ;
Rhyme 0:2b9a6c5fcd52 265 hello() ;
Rhyme 0:2b9a6c5fcd52 266 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 267
Rhyme 0:2b9a6c5fcd52 268 while(1) {
Rhyme 0:2b9a6c5fcd52 269 drawChart() ;
Rhyme 0:2b9a6c5fcd52 270 touched = TSC.getPoint(&x, &y) ;
Rhyme 0:2b9a6c5fcd52 271 if (touched) {
Rhyme 0:2b9a6c5fcd52 272 timer.detach() ;
Rhyme 0:2b9a6c5fcd52 273 result = doMenu(x, y) ;
Rhyme 0:2b9a6c5fcd52 274 if (result != true) {
Rhyme 0:2b9a6c5fcd52 275 result = doTrigValue(x, y) ;
Rhyme 0:2b9a6c5fcd52 276 if (result) {
Rhyme 0:2b9a6c5fcd52 277 drawTrigMark() ;
Rhyme 0:2b9a6c5fcd52 278 printTrigMode() ;
Rhyme 0:2b9a6c5fcd52 279 }
Rhyme 0:2b9a6c5fcd52 280 }
Rhyme 0:2b9a6c5fcd52 281 if (mode == MODE_RUN) {
Rhyme 0:2b9a6c5fcd52 282 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 283 }
Rhyme 0:2b9a6c5fcd52 284 }
Rhyme 0:2b9a6c5fcd52 285 wait(0.1) ;
Rhyme 0:2b9a6c5fcd52 286 }
Rhyme 0:2b9a6c5fcd52 287 }