From 3c5114ba4c087f85ff500696519d309298675bb0 Mon Sep 17 00:00:00 2001 From: Joey Castillo Date: Tue, 5 Jul 2022 22:51:30 -0500 Subject: WIP new tests --- apps/functional-test/app.c | 88 ++++++++++++---------------------------------- 1 file changed, 23 insertions(+), 65 deletions(-) (limited to 'apps/functional-test') diff --git a/apps/functional-test/app.c b/apps/functional-test/app.c index b4ee0412..18599512 100644 --- a/apps/functional-test/app.c +++ b/apps/functional-test/app.c @@ -2,15 +2,6 @@ #include #include "watch.h" -bool even = false; -bool beep = false; -uint32_t i = 0; - -static void cb_tick(void) { - beep = true; - even = !even; -} - void app_init(void) { } @@ -22,30 +13,12 @@ void app_setup(void) { watch_enable_buzzer(); - watch_enable_digital_output(A0); - watch_enable_digital_output(SCL); - watch_enable_digital_output(SDA); - watch_enable_digital_output(A1); - watch_enable_digital_output(A2); - watch_enable_digital_output(A3); - watch_enable_digital_output(A4); - watch_enable_digital_input(BTN_ALARM); watch_enable_digital_input(BTN_LIGHT); watch_enable_digital_input(BTN_MODE); watch_enable_pull_down(BTN_ALARM); watch_enable_pull_down(BTN_LIGHT); watch_enable_pull_down(BTN_MODE); - - watch_set_pin_level(A0, false); - watch_set_pin_level(SCL, false); - watch_set_pin_level(SDA, false); - watch_set_pin_level(A1, false); - watch_set_pin_level(A2, false); - watch_set_pin_level(A3, false); - watch_set_pin_level(A4, false); - - watch_rtc_register_periodic_callback(cb_tick, 2); } void app_prepare_for_standby(void) { @@ -55,51 +28,36 @@ void app_wake_from_standby(void) { } bool app_loop(void) { - char buf[14]; + static int last_button = 0; + static int button = 0; + static int16_t loop = 0; - if (beep) watch_buzzer_play_note(BUZZER_NOTE_E5, 100); - - if (even) { - printf("Flashing even lights\n"); - #ifdef WATCH_SWAP_LED_PINS - sprintf(buf, "WT%2d'blu_E", (uint8_t)(i++ % 40)); - #else - sprintf(buf, "WT%2d'Grn_E", (uint8_t)(i++ % 40)); - #endif - watch_set_led_green(); - watch_set_pin_level(A0, true); - watch_set_pin_level(SCL, false); - watch_set_pin_level(SDA, true); - watch_set_pin_level(A1, false); - watch_set_pin_level(A2, true); - watch_set_pin_level(A3, false); - watch_set_pin_level(A4, true); - } else { - printf("Flashing odd lights\n"); - sprintf(buf, "WT%2d-red~O", (uint8_t)(i++ % 40)); - watch_display_string(buf, 0); - watch_set_led_red(); - watch_set_pin_level(A0, false); - watch_set_pin_level(SCL, true); - watch_set_pin_level(SDA, false); - watch_set_pin_level(A1, true); - watch_set_pin_level(A2, false); - watch_set_pin_level(A3, true); - watch_set_pin_level(A4, false); - } if (watch_get_pin_level(BTN_ALARM)) { - buf[2] = 'a'; - buf[3] = 'L'; + button = 1; } if (watch_get_pin_level(BTN_LIGHT)) { - buf[2] = '1'; - buf[3] = 'i'; + button = 2; } if (watch_get_pin_level(BTN_MODE)) { - buf[2] = '-'; - buf[3] = 'O'; + button = 3; + } + + if (button != last_button) { + last_button = button; + watch_buzzer_play_note(BUZZER_NOTE_C8, 50); + } + + for(int com = 0; com < 3; com++) { + for(int seg = 0; seg < 24; seg++) { + if (loop > 0) { + if (seg % 2 == 0) watch_set_pixel(com, seg); + else watch_set_pixel(com, seg); + } else { + if (seg % 2 == 1) watch_set_pixel(com, seg); + else watch_set_pixel(com, seg); + } + } } - watch_display_string(buf, 0); return true; } -- cgit v1.2.3 From 87da5f15ea314d53d97cee5f9fd13b4f83455256 Mon Sep 17 00:00:00 2001 From: Joey Castillo Date: Tue, 5 Jul 2022 22:53:04 -0500 Subject: new tests --- apps/functional-test/app.c | 38 ++++++++++++++++++++++++-------------- 1 file changed, 24 insertions(+), 14 deletions(-) (limited to 'apps/functional-test') diff --git a/apps/functional-test/app.c b/apps/functional-test/app.c index 18599512..179bea8b 100644 --- a/apps/functional-test/app.c +++ b/apps/functional-test/app.c @@ -13,6 +13,8 @@ void app_setup(void) { watch_enable_buzzer(); + watch_enable_digital_output(RED); + watch_enable_digital_output(GREEN); watch_enable_digital_input(BTN_ALARM); watch_enable_digital_input(BTN_LIGHT); watch_enable_digital_input(BTN_MODE); @@ -30,34 +32,42 @@ void app_wake_from_standby(void) { bool app_loop(void) { static int last_button = 0; static int button = 0; - static int16_t loop = 0; + static int8_t loop = 0; + watch_set_pin_level(GREEN, false); + watch_set_pin_level(RED, false); if (watch_get_pin_level(BTN_ALARM)) { + watch_set_pin_level(GREEN, true); button = 1; - } - if (watch_get_pin_level(BTN_LIGHT)) { + } else if (watch_get_pin_level(BTN_LIGHT)) { + watch_set_pin_level(RED, true); button = 2; - } - if (watch_get_pin_level(BTN_MODE)) { + } else if (watch_get_pin_level(BTN_MODE)) { + watch_set_pin_level(GREEN, true); + watch_set_pin_level(RED, true); button = 3; } if (button != last_button) { last_button = button; - watch_buzzer_play_note(BUZZER_NOTE_C8, 50); + watch_buzzer_play_note(BUZZER_NOTE_C8, 100); } + static const bool segmap[3][24] = { + //0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 + {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0}, + {0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1}, + {1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1} + }; + for(int com = 0; com < 3; com++) { for(int seg = 0; seg < 24; seg++) { - if (loop > 0) { - if (seg % 2 == 0) watch_set_pixel(com, seg); - else watch_set_pixel(com, seg); - } else { - if (seg % 2 == 1) watch_set_pixel(com, seg); - else watch_set_pixel(com, seg); - } + if (segmap[com][seg]) (loop >= 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg); + else (loop < 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg); } } - return true; + loop++; + + return false; } -- cgit v1.2.3