diff options
| author | JF002 <JF002@users.noreply.github.com> | 2021-04-09 20:43:39 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-09 20:43:39 +0200 |
| commit | 17a37acaa81278cc8c782d84d994d4ca938ef006 (patch) | |
| tree | 3c15890315a420417cd96b82103da80c84ed562d /src/displayapp/screens/List.h | |
| parent | 04fc33e2d479161ec261f932b908dffbd73e227f (diff) | |
| parent | 3685095da0d01f137692f80df2c267a8b90da715 (diff) | |
Merge pull request #258 from joaquimorg/BigRewrite
New settings menu and more...
Diffstat (limited to 'src/displayapp/screens/List.h')
| -rw-r--r-- | src/displayapp/screens/List.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/displayapp/screens/List.h b/src/displayapp/screens/List.h new file mode 100644 index 00000000..739a91c3 --- /dev/null +++ b/src/displayapp/screens/List.h @@ -0,0 +1,49 @@ +#pragma once + +#include <lvgl/lvgl.h> +#include <cstdint> +#include <memory> +#include "Screen.h" +#include "../Apps.h" +#include "components/settings/Settings.h" + +#define MAXLISTITEMS 4 + +namespace Pinetime { + namespace Applications { + namespace Screens { + class List : public Screen { + public: + struct Applications { + const char* icon; + const char* name; + Pinetime::Applications::Apps application; + }; + + explicit List(uint8_t screenID, uint8_t numScreens, + DisplayApp* app, + Controllers::Settings& settingsController, + std::array<Applications, MAXLISTITEMS>& applications); + ~List() override; + + bool Refresh() override; + + + void OnButtonEvent(lv_obj_t *object, lv_event_t event); + + private: + + Controllers::Settings& settingsController; + Pinetime::Applications::Apps apps[MAXLISTITEMS]; + + lv_obj_t * itemApps[MAXLISTITEMS]; + + lv_point_t pageIndicatorBasePoints[2]; + lv_point_t pageIndicatorPoints[2]; + lv_obj_t* pageIndicatorBase; + lv_obj_t* pageIndicator; + + }; + } + } +} |
