From b7699d86b00038f43a279e7f365ccd56ff97fc62 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Nils=20Forss=C3=A9n?= Date: Sun, 6 Nov 2022 22:09:16 +0100 Subject: [PATCH] pushing --- main/Peripherals.cpp | 9 ++++-- main/Peripherals.h | 7 +++-- main/main.cpp | 66 ++++++++++++++++++++++++++++++++++++++------ 3 files changed, 68 insertions(+), 14 deletions(-) diff --git a/main/Peripherals.cpp b/main/Peripherals.cpp index d76083f..de8d405 100644 --- a/main/Peripherals.cpp +++ b/main/Peripherals.cpp @@ -83,13 +83,12 @@ int Potentiometer::get_raw() { return sum / SAMPLES; } -int Potentiometer::update() { +void Potentiometer::update() { prev_raw = (get_raw() + (prev_raw*(AVERAGESUM - 1))) / AVERAGESUM; if (on_change != NULL) { //Check threshold and maybe send update to function } - return prev_raw; } float Potentiometer::get_percent() { @@ -115,3 +114,9 @@ bool Button::getPressedSingle() { lastState = state; return ret; } + +void Button::update() { + if (on_change != NULL) && getPressedSingle() { + (*on_change)(); + } +} diff --git a/main/Peripherals.h b/main/Peripherals.h index 83bbbcc..3fb4d0d 100644 --- a/main/Peripherals.h +++ b/main/Peripherals.h @@ -11,8 +11,8 @@ #define atten ADC_ATTEN_DB_2_5 #define width ADC_WIDTH_BIT_12 -typedef void(*pot_update_callback_t)(float); -typedef void(*btn_update_callback_t)(bool); +typedef void(*pot_update_callback_t)(); +typedef void(*btn_update_callback_t)(); @@ -21,7 +21,7 @@ public: Potentiometer(const int, const int, pot_update_callback_t = NULL); Potentiometer(const adc_unit_t, const adc_channel_t, const int, const int, pot_update_callback_t = NULL); int get_raw(); - int update(); + void update(); float get_percent(); private: @@ -43,6 +43,7 @@ public: Button(gpio_num_t, btn_update_callback_t = NULL); bool getPressed(); bool getPressedSingle(); + void update(); btn_update_callback_t on_change; private: bool lastState = false; diff --git a/main/main.cpp b/main/main.cpp index 4ae1e12..e2e76e0 100644 --- a/main/main.cpp +++ b/main/main.cpp @@ -81,19 +81,28 @@ void update_display(al_event_cb_t, al_event_cb_param_t*); void IRAM_ATTR draw(); bool IRAM_ATTR input_timer_cb(void* args); bool IRAM_ATTR display_timer_cb(void* args); + +pot_update_callback_t pot1_update_cb(void); +pot_update_callback_t pot2_update_cb(void); +pot_update_callback_t pot3_update_cb(void); +pot_update_callback_t pot4_update_cb(void); + +btn_update_callback_t btn1_update_cb(void); +btn_update_callback_t btn2_update_cb(void); +btn_update_callback_t btn3_update_cb(void); // -------------------------------------------------- // -------------- Object definitions -------------- Audiolib Audiosource = Audiolib("HESA PETTER", &update_display); -//Potentiometer* pot1 = new Potentiometer(ADC_UNIT_2, POT1_CHANNEL, 70, 1010); //65/66 -> 572/573 -> 1019 -//Potentiometer* pot2 = new Potentiometer(ADC1_CHANNEL_4, 41, 988); -//Potentiometer* pot3 = new Potentiometer(ADC1_CHANNEL_6, 38, 988); -//Potentiometer* pot4 = new Potentiometer(ADC1_CHANNEL_7, 29, 990); +Potentiometer* pot1 = new Potentiometer(ADC1_CHANNEL0, 70, 1010, &pot1_update_cb); +Potentiometer* pot2 = new Potentiometer(ADC1_CHANNEL_4, 41, 988, &pot2_update_cb); +Potentiometer* pot3 = new Potentiometer(ADC1_CHANNEL_6, 38, 988, &pot3_update_cb); +Potentiometer* pot4 = new Potentiometer(ADC1_CHANNEL_7, 29, 990, &pot4_update_cb); -//Button* btn1 = new Button(BTN1_PIN); -//Button* btn2 = new Button(BTN2_PIN); -//Button* btn3 = new Button(BTN3_PIN); +Button* btn1 = new Button(BTN1_PIN, &btn1_update_cb); +Button* btn2 = new Button(BTN2_PIN, &btn2_update_cb); +Button* btn3 = new Button(BTN3_PIN, &btn3_update_cb); CombinedChannelFilter* highshelf_filter = new CombinedChannelFilter(new Filter(HIGHSHELF, 2000, 44100, 0.8, 0), new Filter(HIGHSHELF, 2000, 44100, 0.8, 0)); CombinedChannelFilter* lowshelf_filter = new CombinedChannelFilter(new Filter(LOWSHELF, 250, 44100, 0.8, 0), new Filter(LOWSHELF, 250, 44100, 0.8, 0)); @@ -154,8 +163,18 @@ extern "C" { xQueueReceive(event_queue, &event, portMAX_DELAY); if (event & DISPLAY) { draw(); - }/* + } if (event & INPUT) { + + pot1->update(); + pot2->update(); + pot3->update(); + pot4->update(); + + btn1->update(); + btn2->update(); + btn3->update(); + if (btn1->getPressedSingle()){ Audiosource.previous(); } @@ -170,7 +189,7 @@ extern "C" { if (btn3->getPressedSingle()) { Audiosource.next(); } - }*/ + } } } } @@ -265,4 +284,33 @@ bool display_timer_cb(void* args) { BaseType_t high_task_awoken = pdFALSE; xQueueSendFromISR(event_queue, &msg, &high_task_awoken); return high_task_awoken == pdTRUE; +} + +pot_update_callback_t pot1_update_cb() { + printf("Pot 1 changed\n"); +} +pot_update_callback_t pot2_update_cb() { + printf("Pot 2 changed\n"); +} +pot_update_callback_t pot3_update_cb() { + printf("Pot 3 changed\n"); +} +pot_update_callback_t pot4_update_cb() { + printf("Pot 4 changed\n"); +} + + +btn_update_callback_t btn1_update_cb() { + Audiosource.previous(); +} +btn_update_callback_t btn2_update_cb() { + if (displayStatus & PLAY) { + Audiosource.pause(); + } + else if (displayStatus & (PAUSE | STOP)){ + Audiosource.play(); + } +} +btn_update_callback_t btn3_update_cb() { + Audiosource.next(); } \ No newline at end of file -- 2.30.2