From e3fb2f0b8974f3e9a124d27f4b568e754ccfb782 Mon Sep 17 00:00:00 2001 From: Avamander Date: Fri, 2 Oct 2020 21:46:41 +0300 Subject: Renamed DisplayApp/ to displayapp/ --- src/displayapp/Screens/ScreenList.h | 66 +++++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) create mode 100644 src/displayapp/Screens/ScreenList.h (limited to 'src/displayapp/Screens/ScreenList.h') diff --git a/src/displayapp/Screens/ScreenList.h b/src/displayapp/Screens/ScreenList.h new file mode 100644 index 00000000..d873336d --- /dev/null +++ b/src/displayapp/Screens/ScreenList.h @@ -0,0 +1,66 @@ +#pragma once + +#include +#include +#include +#include "Screen.h" +#include "Label.h" + +namespace Pinetime { + namespace Applications { + namespace Screens { + template + class ScreenList : public Screen { + public: + ScreenList(DisplayApp* app, std::array()>, N>&& screens) + : Screen(app), screens{std::move(screens)}, current{this->screens[0]()} { + + } + + ~ScreenList() override { + + } + + bool Refresh() override { + running = current->Refresh(); + return running; + } + + bool OnButtonPushed() override { + running = false; + return true; + } + + bool OnTouchEvent(TouchEvents event) override { + switch (event) { + case TouchEvents::SwipeDown: + if (screenIndex > 0) { + current.reset(nullptr); + app->SetFullRefresh(DisplayApp::FullRefreshDirections::Down); + screenIndex--; + current = screens[screenIndex](); + } + return true; + case TouchEvents::SwipeUp: + if (screenIndex < screens.size() - 1) { + current.reset(nullptr); + app->SetFullRefresh(DisplayApp::FullRefreshDirections::Up); + screenIndex++; + current = screens[screenIndex](); + } + return true; + default: + return false; + } + return false; + } + + private: + bool running = true; + uint8_t screenIndex = 0; + std::array()>, N> screens; + std::unique_ptr current; + }; + } + } +} \ No newline at end of file -- cgit v1.2.3-70-g09d2