diff options
| author | Riku Isokoski <riksu9000@gmail.com> | 2022-05-20 08:55:40 (GMT) |
|---|---|---|
| committer | Michele Bini <michele.bini@gmail.com> | 2022-06-07 03:01:47 (GMT) |
| commit | d4224e1ce2f6825f07e23a0b1ec1963bfa03f37c (patch) | |
| tree | 205372acb7abb84efe19361e27faf5f88a982803 /src/displayapp/screens/ApplicationList.cpp | |
| parent | 6f169f67a2e7fe926092655cb68e7672b61bd8e3 (diff) | |
Automatically create enough screens for all apps and settings
Diffstat (limited to 'src/displayapp/screens/ApplicationList.cpp')
| -rw-r--r-- | src/displayapp/screens/ApplicationList.cpp | 73 |
1 files changed, 19 insertions, 54 deletions
diff --git a/src/displayapp/screens/ApplicationList.cpp b/src/displayapp/screens/ApplicationList.cpp index de1f728..f04b9ef 100644 --- a/src/displayapp/screens/ApplicationList.cpp +++ b/src/displayapp/screens/ApplicationList.cpp @@ -1,13 +1,23 @@ #include "displayapp/screens/ApplicationList.h" #include <lvgl/lvgl.h> #include <array> -#include "displayapp/screens/Symbols.h" -#include "displayapp/screens/Tile.h" #include "displayapp/Apps.h" #include "displayapp/DisplayApp.h" using namespace Pinetime::Applications::Screens; +constexpr std::array<Tile::Applications, ApplicationList::applications.size()> ApplicationList::applications; + +auto ApplicationList::CreateScreenList() const { + std::array<std::function<std::unique_ptr<Screen>()>, nScreens> screens; + for (size_t i = 0; i < screens.size(); i++) { + screens[i] = [this, i]() -> std::unique_ptr<Screen> { + return CreateScreen(i); + }; + } + return screens; +} + ApplicationList::ApplicationList(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController, Pinetime::Controllers::Battery& batteryController, @@ -16,20 +26,7 @@ ApplicationList::ApplicationList(Pinetime::Applications::DisplayApp* app, settingsController {settingsController}, batteryController {batteryController}, dateTimeController {dateTimeController}, - screens {app, - settingsController.GetAppMenu(), - { - [this]() -> std::unique_ptr<Screen> { - return CreateScreen1(); - }, - [this]() -> std::unique_ptr<Screen> { - return CreateScreen2(); - }, - [this]() -> std::unique_ptr<Screen> { - return CreateScreen3(); - } - }, - Screens::ScreenListModes::UpDown} { + screens {app, settingsController.GetAppMenu(), CreateScreenList(), Screens::ScreenListModes::UpDown} { } ApplicationList::~ApplicationList() { @@ -40,44 +37,12 @@ bool ApplicationList::OnTouchEvent(Pinetime::Applications::TouchEvents event) { return screens.OnTouchEvent(event); } -std::unique_ptr<Screen> ApplicationList::CreateScreen1() { - std::array<Screens::Tile::Applications, 6> applications {{ - {Symbols::stopWatch, Apps::StopWatch}, - {Symbols::clock, Apps::Alarm}, - {Symbols::hourGlass, Apps::Timer}, - {Symbols::shoe, Apps::Steps}, - {Symbols::heartBeat, Apps::HeartRate}, - {Symbols::music, Apps::Music}, - }}; +std::unique_ptr<Screen> ApplicationList::CreateScreen(unsigned int screenNum) const { + std::array<Tile::Applications, 6> apps; + for (int i = 0; i < 6; i++) { + apps[i] = applications[screenNum * 6 + i]; + } - return std::make_unique<Screens::Tile>(0, 3, app, settingsController, batteryController, dateTimeController, applications); + return std::make_unique<Screens::Tile>(screenNum, nScreens, app, settingsController, batteryController, dateTimeController, apps); } -std::unique_ptr<Screen> ApplicationList::CreateScreen2() { - std::array<Screens::Tile::Applications, 6> applications {{ - {Symbols::paintbrush, Apps::Paint}, - {Symbols::paddle, Apps::Paddle}, - {"2", Apps::Twos}, - {Symbols::chartLine, Apps::Motion}, - {Symbols::drum, Apps::Metronome}, - {Symbols::map, Apps::Navigation}, - }}; - - return std::make_unique<Screens::Tile>(1, 3, app, settingsController, batteryController, dateTimeController, applications); -} - -std::unique_ptr<Screen> ApplicationList::CreateScreen3() { - std::array<Screens::Tile::Applications, 6> applications { - { - - {Symbols::drum, Apps::Jumpscore}, - {"", Apps::None}, - {"B", Apps::Navigation}, - {"C", Apps::Clock}, - {"E", Apps::SysInfo}, - {"", Apps::None} - } - }; - - return std::make_unique<Screens::Tile>(2, 3, app, settingsController, batteryController, dateTimeController, applications); -} |
