From 39f7545cd5ef7a30bbd482f3579df7744c6b688d Mon Sep 17 00:00:00 2001 From: jacqueline Date: Fri, 7 Jul 2023 15:29:47 +1000 Subject: wire up the playing screen with some real data Includes implementing song duration calculation for CBR MP3 files --- src/ui/ui_fsm.cpp | 49 +++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 39 insertions(+), 10 deletions(-) (limited to 'src/ui/ui_fsm.cpp') diff --git a/src/ui/ui_fsm.cpp b/src/ui/ui_fsm.cpp index 13658c37..5394311c 100644 --- a/src/ui/ui_fsm.cpp +++ b/src/ui/ui_fsm.cpp @@ -19,6 +19,7 @@ #include "screen_track_browser.hpp" #include "system_events.hpp" #include "touchwheel.hpp" +#include "track_queue.hpp" namespace ui { @@ -27,6 +28,8 @@ static constexpr char kTag[] = "ui_fsm"; static const std::size_t kRecordsPerPage = 10; drivers::IGpios* UiState::sIGpios; +audio::TrackQueue* UiState::sQueue; + std::shared_ptr UiState::sTouchWheel; std::shared_ptr UiState::sRelativeWheel; std::shared_ptr UiState::sDisplay; @@ -34,10 +37,11 @@ std::weak_ptr UiState::sDb; std::stack> UiState::sScreens; std::shared_ptr UiState::sCurrentScreen; -std::unique_ptr UiState::sPlayingScreen; -auto UiState::Init(drivers::IGpios* gpio_expander) -> bool { +auto UiState::Init(drivers::IGpios* gpio_expander, audio::TrackQueue* queue) + -> bool { sIGpios = gpio_expander; + sQueue = queue; lv_init(); sDisplay.reset( @@ -70,6 +74,14 @@ void UiState::PushScreen(std::shared_ptr screen) { sCurrentScreen = screen; } +void UiState::PopScreen() { + if (sScreens.empty()) { + return; + } + sCurrentScreen = sScreens.top(); + sScreens.pop(); +} + namespace states { void Splash::exit() { @@ -107,12 +119,9 @@ void Browse::react(const internal::RecordSelected& ev) { if (ev.record.track()) { ESP_LOGI(kTag, "selected track '%s'", ev.record.text()->c_str()); // TODO(jacqueline): We should also send some kind of playlist info here. - auto track = ev.record.track().value(); - events::Dispatch(audio::PlayTrack{ - .id = track.data().id(), - .data = track.data(), - }); - PushScreen(std::make_shared(track)); + sQueue->Clear(); + sQueue->AddLast(ev.record.track()->data().id()); + transit(); } else { ESP_LOGI(kTag, "selected record '%s'", ev.record.text()->c_str()); auto cont = ev.record.Expand(kRecordsPerPage); @@ -138,8 +147,28 @@ void Browse::react(const internal::IndexSelected& ev) { std::move(query))); } -void Playing::react(const audio::PlaybackUpdate ev) { - sPlayingScreen->UpdateTime(ev.seconds_elapsed); +static std::shared_ptr sPlayingScreen; + +void Playing::entry() { + sPlayingScreen.reset(new screens::Playing(sDb, sQueue)); + PushScreen(sPlayingScreen); +} + +void Playing::exit() { + sPlayingScreen.reset(); + PopScreen(); +} + +void Playing::react(const audio::PlaybackStarted& ev) { + sPlayingScreen->OnTrackUpdate(); +} + +void Playing::react(const audio::PlaybackUpdate& ev) { + sPlayingScreen->OnPlaybackUpdate(ev.seconds_elapsed, ev.seconds_total); +} + +void Playing::react(const audio::QueueUpdate& ev) { + sPlayingScreen->OnQueueUpdate(); } } // namespace states -- cgit v1.2.3