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:
Wed Nov 25 12:52:28 2015 +0000
Revision:
7:e58e106c6232
Parent:
3:ea0c3cffa988
FRDM-KL25Z, FRDM-K64F, NUCLEO-F411RE tested

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 3:ea0c3cffa988 13 #include <ILI9341.h>
Rhyme 0:2b9a6c5fcd52 14 #include "Arial12x12.h"
Rhyme 0:2b9a6c5fcd52 15 #include "Arial24x23.h"
Rhyme 0:2b9a6c5fcd52 16 #include "Arial28x28.h"
Rhyme 3:ea0c3cffa988 17 #include "Arial43x48_numb.h"
Rhyme 3:ea0c3cffa988 18 #include "SPI_STMPE610.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 7:e58e106c6232 29 DigitalOut tsc_cs(PIN_CS_TSC, 1) ;
Rhyme 7:e58e106c6232 30 DigitalOut backlight(PIN_BL_TFT, 0) ;
Rhyme 0:2b9a6c5fcd52 31
Rhyme 3:ea0c3cffa988 32 ILI9341 TFT(SPI_8, 10000000,
Rhyme 3:ea0c3cffa988 33 PIN_MOSI, PIN_MISO, PIN_SCLK,
Rhyme 3:ea0c3cffa988 34 PIN_CS_TFT, PIN_RESET_TFT, PIN_DC_TFT, "Adafruit2.8") ;
Rhyme 0:2b9a6c5fcd52 35 SPI_STMPE610 TSC(PIN_MOSI, PIN_MISO, PIN_SCLK, PIN_CS_TSC) ;
Rhyme 0:2b9a6c5fcd52 36 TFTMenuItem *menu[NUM_MAX_MENU] ;
Rhyme 0:2b9a6c5fcd52 37 int numMenu = 0 ;
Rhyme 0:2b9a6c5fcd52 38
Rhyme 0:2b9a6c5fcd52 39 float vref = 3.28 ; // input range 0 - 3.3V
Rhyme 0:2b9a6c5fcd52 40 uint16_t udata[2][NUM_MAX_ANALOG_CH][CHART_LEN] ; // data storage ;
Rhyme 0:2b9a6c5fcd52 41 uint16_t bor[2] = {0, 0} ; // begin of ring buffer
Rhyme 0:2b9a6c5fcd52 42 int data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 43 int numAnalogIn = 2 ;
Rhyme 0:2b9a6c5fcd52 44 int memLength = CHART_LEN ;
Rhyme 0:2b9a6c5fcd52 45 int us_interval = MIN_INTERVAL ; // 20us = 50KHz
Rhyme 0:2b9a6c5fcd52 46 bool frame_full = false ;
Rhyme 0:2b9a6c5fcd52 47 int page = 0 ; //
Rhyme 0:2b9a6c5fcd52 48 int prev_page = 0 ;
Rhyme 0:2b9a6c5fcd52 49 int mode = MODE_RUN ;
Rhyme 0:2b9a6c5fcd52 50
Rhyme 0:2b9a6c5fcd52 51 void sampleAD(void) ;
Rhyme 0:2b9a6c5fcd52 52 void drawMenu(void) ;
Rhyme 0:2b9a6c5fcd52 53 // void eraseGraphFrames(void) ;
Rhyme 0:2b9a6c5fcd52 54
Rhyme 0:2b9a6c5fcd52 55 /**
Rhyme 0:2b9a6c5fcd52 56 * u2v unsigned int data value to voltage conversion
Rhyme 0:2b9a6c5fcd52 57 */
Rhyme 0:2b9a6c5fcd52 58 float u2v(uint16_t uvalue)
Rhyme 0:2b9a6c5fcd52 59 {
Rhyme 0:2b9a6c5fcd52 60 return( vref * (float)uvalue / 65535.0 ) ;
Rhyme 0:2b9a6c5fcd52 61 }
Rhyme 0:2b9a6c5fcd52 62
Rhyme 0:2b9a6c5fcd52 63 /**
Rhyme 0:2b9a6c5fcd52 64 * v2u voltage to unsigned int data conversion
Rhyme 0:2b9a6c5fcd52 65 */
Rhyme 0:2b9a6c5fcd52 66 uint16_t v2u(float voltage)
Rhyme 0:2b9a6c5fcd52 67 {
Rhyme 0:2b9a6c5fcd52 68 return(0xFFFF * voltage / vref) ;
Rhyme 0:2b9a6c5fcd52 69 }
Rhyme 0:2b9a6c5fcd52 70
Rhyme 0:2b9a6c5fcd52 71 /**
Rhyme 0:2b9a6c5fcd52 72 * u2f unsigned int to float (0 - 1.0) conversion
Rhyme 0:2b9a6c5fcd52 73 */
Rhyme 0:2b9a6c5fcd52 74 float u2f(uint16_t value)
Rhyme 0:2b9a6c5fcd52 75 {
Rhyme 0:2b9a6c5fcd52 76 return( (float)value / 65535.0 ) ;
Rhyme 0:2b9a6c5fcd52 77 }
Rhyme 0:2b9a6c5fcd52 78
Rhyme 0:2b9a6c5fcd52 79 void initADC(void)
Rhyme 0:2b9a6c5fcd52 80 {
Rhyme 0:2b9a6c5fcd52 81 if (numAnalogIn > 0) {
Rhyme 7:e58e106c6232 82 ach[0] = new AnalogIn(PIN_ADC_CH0) ;
Rhyme 0:2b9a6c5fcd52 83 }
Rhyme 0:2b9a6c5fcd52 84 if (numAnalogIn > 1) {
Rhyme 7:e58e106c6232 85 ach[1] = new AnalogIn(PIN_ADC_CH1) ;
Rhyme 0:2b9a6c5fcd52 86 }
Rhyme 0:2b9a6c5fcd52 87
Rhyme 7:e58e106c6232 88 #if defined (TARGET_KL25Z)
Rhyme 0:2b9a6c5fcd52 89 ADC0->CFG1 = ADC0->CFG1 & (
Rhyme 0:2b9a6c5fcd52 90 ~(
Rhyme 0:2b9a6c5fcd52 91 0x80 // LDLPC = 0 ; no low-power mode
Rhyme 0:2b9a6c5fcd52 92 | 0x60 // ADIV = 1
Rhyme 0:2b9a6c5fcd52 93 | 0x10 // Sample time short
Rhyme 0:2b9a6c5fcd52 94 | 0x03 // input clock = BUS CLK
Rhyme 0:2b9a6c5fcd52 95 )
Rhyme 0:2b9a6c5fcd52 96 ) ; // clkdiv <= 1
Rhyme 0:2b9a6c5fcd52 97 ADC0->CFG2 = ADC0->CFG2
Rhyme 0:2b9a6c5fcd52 98 | 0x03 ; // Logsample Time 11 = 2 extra ADCK
Rhyme 0:2b9a6c5fcd52 99 ADC0->SC3 = ADC0->SC3
Rhyme 0:2b9a6c5fcd52 100 & (~(0x03)) ; // hardware avarage off
Rhyme 7:e58e106c6232 101 #endif
Rhyme 0:2b9a6c5fcd52 102 }
Rhyme 0:2b9a6c5fcd52 103
Rhyme 0:2b9a6c5fcd52 104 void envChanged(void)
Rhyme 0:2b9a6c5fcd52 105 {
Rhyme 0:2b9a6c5fcd52 106 timer.detach() ;
Rhyme 0:2b9a6c5fcd52 107
Rhyme 0:2b9a6c5fcd52 108 eraseGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 109 drawGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 110
Rhyme 0:2b9a6c5fcd52 111 data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 112 page = 0 ;
Rhyme 0:2b9a6c5fcd52 113 prev_page = 0 ;
Rhyme 0:2b9a6c5fcd52 114 frame_full = false ;
Rhyme 0:2b9a6c5fcd52 115 if (trig_mode == TRIG_MODE_NONE) {
Rhyme 0:2b9a6c5fcd52 116 sampling_status = ST_TRIG_HIT ;
Rhyme 0:2b9a6c5fcd52 117 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 118 } else {
Rhyme 0:2b9a6c5fcd52 119 sampling_status = ST_PRE_TRIG ;
Rhyme 0:2b9a6c5fcd52 120 }
Rhyme 0:2b9a6c5fcd52 121 /*
Rhyme 0:2b9a6c5fcd52 122 if (mode == MODE_RUN) {
Rhyme 0:2b9a6c5fcd52 123 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 124 }
Rhyme 0:2b9a6c5fcd52 125 */
Rhyme 0:2b9a6c5fcd52 126 }
Rhyme 0:2b9a6c5fcd52 127
Rhyme 0:2b9a6c5fcd52 128 bool checkTrigger(void)
Rhyme 0:2b9a6c5fcd52 129 {
Rhyme 0:2b9a6c5fcd52 130 bool result = false ;
Rhyme 0:2b9a6c5fcd52 131 int prev_index ;
Rhyme 0:2b9a6c5fcd52 132 uint16_t current, prev ;
Rhyme 0:2b9a6c5fcd52 133 if (data_index > 0) {
Rhyme 0:2b9a6c5fcd52 134 prev_index = data_index - 1 ;
Rhyme 0:2b9a6c5fcd52 135 } else {
Rhyme 0:2b9a6c5fcd52 136 prev_index = memLength - 1 ; // memLength - 1 ;
Rhyme 0:2b9a6c5fcd52 137 }
Rhyme 0:2b9a6c5fcd52 138 current = udata[page][trig_ch][data_index] ;
Rhyme 0:2b9a6c5fcd52 139 prev = udata[page][trig_ch][prev_index] ;
Rhyme 0:2b9a6c5fcd52 140
Rhyme 0:2b9a6c5fcd52 141 switch(trig_mode) {
Rhyme 0:2b9a6c5fcd52 142 case TRIG_MODE_NONE: // no trigger, return true at the beggining
Rhyme 0:2b9a6c5fcd52 143 trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 144 result = true ;
Rhyme 0:2b9a6c5fcd52 145 break ;
Rhyme 0:2b9a6c5fcd52 146 case TRIG_MODE_RISE:
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_FALL:
Rhyme 0:2b9a6c5fcd52 152 if ((prev > utrig_level)&&(utrig_level >= current)) {
Rhyme 0:2b9a6c5fcd52 153 result = true ;
Rhyme 0:2b9a6c5fcd52 154 }
Rhyme 0:2b9a6c5fcd52 155 break ;
Rhyme 0:2b9a6c5fcd52 156 case TRIG_MODE_LEVEL:
Rhyme 0:2b9a6c5fcd52 157 if (current > trig_level_margin) {
Rhyme 0:2b9a6c5fcd52 158 if (((current + trig_level_margin) >= utrig_level)&&(utrig_level >= (current - trig_level_margin))) {
Rhyme 0:2b9a6c5fcd52 159 result = true ;
Rhyme 0:2b9a6c5fcd52 160 }
Rhyme 0:2b9a6c5fcd52 161 } else {
Rhyme 0:2b9a6c5fcd52 162 if ((current + trig_level_margin) >= utrig_level) {
Rhyme 0:2b9a6c5fcd52 163 result = true ;
Rhyme 0:2b9a6c5fcd52 164 }
Rhyme 0:2b9a6c5fcd52 165 }
Rhyme 0:2b9a6c5fcd52 166 break ;
Rhyme 0:2b9a6c5fcd52 167 default:
Rhyme 0:2b9a6c5fcd52 168 printf("Error: Unknown trigger mode %d\n", trig_mode) ;
Rhyme 0:2b9a6c5fcd52 169 break ;
Rhyme 0:2b9a6c5fcd52 170 }
Rhyme 0:2b9a6c5fcd52 171 return( result ) ;
Rhyme 0:2b9a6c5fcd52 172 }
Rhyme 0:2b9a6c5fcd52 173
Rhyme 0:2b9a6c5fcd52 174 void sampleAD(void)
Rhyme 0:2b9a6c5fcd52 175 {
Rhyme 0:2b9a6c5fcd52 176 if (frame_full) {
Rhyme 0:2b9a6c5fcd52 177 return ;
Rhyme 0:2b9a6c5fcd52 178 }
Rhyme 0:2b9a6c5fcd52 179 // timer.detach() ;
Rhyme 0:2b9a6c5fcd52 180 for (int i = 0 ; i < numAnalogIn ; i++ ) {
Rhyme 0:2b9a6c5fcd52 181 udata[page][i][data_index] = ach[i]->read_u16() ;
Rhyme 0:2b9a6c5fcd52 182 }
Rhyme 0:2b9a6c5fcd52 183 // timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 184 switch(sampling_status) {
Rhyme 0:2b9a6c5fcd52 185 case ST_PRE_TRIG:
Rhyme 0:2b9a6c5fcd52 186 if (data_index >= trig_pos) {
Rhyme 0:2b9a6c5fcd52 187 sampling_status = ST_TRIG_WAIT ;
Rhyme 0:2b9a6c5fcd52 188 } else {
Rhyme 0:2b9a6c5fcd52 189 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 190 }
Rhyme 0:2b9a6c5fcd52 191 break ;
Rhyme 0:2b9a6c5fcd52 192 case ST_TRIG_WAIT:
Rhyme 0:2b9a6c5fcd52 193 if (checkTrigger()) {
Rhyme 0:2b9a6c5fcd52 194 trig_index = data_index ;
Rhyme 0:2b9a6c5fcd52 195 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 196 sampling_status = ST_TRIG_HIT ;
Rhyme 0:2b9a6c5fcd52 197 } else {
Rhyme 0:2b9a6c5fcd52 198 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 199 }
Rhyme 0:2b9a6c5fcd52 200 break ;
Rhyme 0:2b9a6c5fcd52 201 case ST_TRIG_HIT:
Rhyme 0:2b9a6c5fcd52 202 post_trig_index++ ;
Rhyme 0:2b9a6c5fcd52 203 if (post_trig_index >= post_trig_len) {
Rhyme 0:2b9a6c5fcd52 204 sampling_status = ST_BUF_FULL ;
Rhyme 0:2b9a6c5fcd52 205 frame_full = true ;
Rhyme 0:2b9a6c5fcd52 206 bor[page] = (memLength + trig_index - trig_pos) % memLength ;
Rhyme 0:2b9a6c5fcd52 207 post_trig_index = 0 ;
Rhyme 0:2b9a6c5fcd52 208 data_index = 0 ;
Rhyme 0:2b9a6c5fcd52 209 } else {
Rhyme 0:2b9a6c5fcd52 210 data_index = (data_index + 1) % memLength ;
Rhyme 0:2b9a6c5fcd52 211 }
Rhyme 0:2b9a6c5fcd52 212 break ;
Rhyme 0:2b9a6c5fcd52 213 case ST_BUF_FULL:
Rhyme 0:2b9a6c5fcd52 214 printf("mode = ST_BUF_FULL\n\r") ;
Rhyme 0:2b9a6c5fcd52 215 break ;
Rhyme 0:2b9a6c5fcd52 216 default:
Rhyme 0:2b9a6c5fcd52 217 printf("unknown sample status %d\n", sampling_status) ;
Rhyme 0:2b9a6c5fcd52 218 break ;
Rhyme 0:2b9a6c5fcd52 219 }
Rhyme 0:2b9a6c5fcd52 220 }
Rhyme 0:2b9a6c5fcd52 221
Rhyme 0:2b9a6c5fcd52 222
Rhyme 0:2b9a6c5fcd52 223 bool doTrigValue(int x, int y)
Rhyme 0:2b9a6c5fcd52 224 {
Rhyme 0:2b9a6c5fcd52 225 int i, y_offset ;
Rhyme 0:2b9a6c5fcd52 226 bool result = false ;
Rhyme 0:2b9a6c5fcd52 227 for (i = 0 ; i < numAnalogIn ; i++ ) {
Rhyme 0:2b9a6c5fcd52 228 if (inChFrame(i, x, y)) {
Rhyme 0:2b9a6c5fcd52 229 result = true ;
Rhyme 0:2b9a6c5fcd52 230 trig_ch = i ;
Rhyme 0:2b9a6c5fcd52 231 trig_pos = x - left_margin;
Rhyme 0:2b9a6c5fcd52 232 post_trig_len = memLength - trig_pos ;
Rhyme 0:2b9a6c5fcd52 233 y_offset = head_h + (pane_h + 5) * i + 1;
Rhyme 0:2b9a6c5fcd52 234 trig_level = vref *(1 - ((float)(y - y_offset) / (float)(pane_h - 2))) ;
Rhyme 0:2b9a6c5fcd52 235 if (trig_level > vref) {
Rhyme 0:2b9a6c5fcd52 236 trig_level = vref ;
Rhyme 0:2b9a6c5fcd52 237 } else if (trig_level < 0.0) {
Rhyme 0:2b9a6c5fcd52 238 trig_level = 0.0 ;
Rhyme 0:2b9a6c5fcd52 239 }
Rhyme 0:2b9a6c5fcd52 240 utrig_level = v2u( trig_level ) ;
Rhyme 0:2b9a6c5fcd52 241 break ;
Rhyme 0:2b9a6c5fcd52 242 }
Rhyme 0:2b9a6c5fcd52 243 }
Rhyme 0:2b9a6c5fcd52 244 return( result ) ;
Rhyme 0:2b9a6c5fcd52 245 }
Rhyme 0:2b9a6c5fcd52 246
Rhyme 0:2b9a6c5fcd52 247 void hello()
Rhyme 0:2b9a6c5fcd52 248 {
Rhyme 0:2b9a6c5fcd52 249 printf("=== simple oscilloscope ===\n\r") ;
Rhyme 0:2b9a6c5fcd52 250 printf("built: %s\n\r",__DATE__) ;
Rhyme 0:2b9a6c5fcd52 251 }
Rhyme 0:2b9a6c5fcd52 252
Rhyme 0:2b9a6c5fcd52 253 int main()
Rhyme 0:2b9a6c5fcd52 254 {
Rhyme 0:2b9a6c5fcd52 255 int touched ;
Rhyme 0:2b9a6c5fcd52 256 uint16_t x, y ;
Rhyme 0:2b9a6c5fcd52 257 bool result ;
Rhyme 0:2b9a6c5fcd52 258 tty.cls() ;
Rhyme 0:2b9a6c5fcd52 259 backlight = 0 ;
Rhyme 0:2b9a6c5fcd52 260 initTFT() ;
Rhyme 0:2b9a6c5fcd52 261 initADC() ;
Rhyme 0:2b9a6c5fcd52 262 initMenu() ;
Rhyme 0:2b9a6c5fcd52 263
Rhyme 0:2b9a6c5fcd52 264 us_interval = MIN_INTERVAL ;
Rhyme 0:2b9a6c5fcd52 265
Rhyme 0:2b9a6c5fcd52 266 drawGraphFrames() ;
Rhyme 0:2b9a6c5fcd52 267 drawMenu() ;
Rhyme 0:2b9a6c5fcd52 268
Rhyme 0:2b9a6c5fcd52 269 backlight = 1 ;
Rhyme 0:2b9a6c5fcd52 270 hello() ;
Rhyme 0:2b9a6c5fcd52 271 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 272 while(1) {
Rhyme 0:2b9a6c5fcd52 273 drawChart() ;
Rhyme 0:2b9a6c5fcd52 274 touched = TSC.getPoint(&x, &y) ;
Rhyme 2:4b9260139892 275 if (touched && ((x != 0)||(y != 0))) { // TSC sometimes returns (0,0)
Rhyme 7:e58e106c6232 276 if (mode == MODE_RUN) {
Rhyme 7:e58e106c6232 277 timer.detach() ;
Rhyme 7:e58e106c6232 278 }
Rhyme 0:2b9a6c5fcd52 279 result = doMenu(x, y) ;
Rhyme 0:2b9a6c5fcd52 280 if (result != true) {
Rhyme 0:2b9a6c5fcd52 281 result = doTrigValue(x, y) ;
Rhyme 0:2b9a6c5fcd52 282 if (result) {
Rhyme 0:2b9a6c5fcd52 283 drawTrigMark() ;
Rhyme 0:2b9a6c5fcd52 284 printTrigMode() ;
Rhyme 0:2b9a6c5fcd52 285 }
Rhyme 0:2b9a6c5fcd52 286 }
Rhyme 0:2b9a6c5fcd52 287 if (mode == MODE_RUN) {
Rhyme 0:2b9a6c5fcd52 288 timer.attach_us(&sampleAD, us_interval) ;
Rhyme 0:2b9a6c5fcd52 289 }
Rhyme 0:2b9a6c5fcd52 290 }
Rhyme 0:2b9a6c5fcd52 291 wait(0.1) ;
Rhyme 0:2b9a6c5fcd52 292 }
Rhyme 0:2b9a6c5fcd52 293 }