[WIP] Add new notification UI that use HW scrolling effects. Both notification apps are available in the menu, we can compare them.

This commit is contained in:
JF 2020-10-19 21:46:41 +02:00
parent 28bc434419
commit 55427d83b8
8 changed files with 356 additions and 96 deletions

View file

@ -342,6 +342,7 @@ list(APPEND SOURCE_FILES
displayapp/screens/FirmwareValidation.cpp displayapp/screens/FirmwareValidation.cpp
displayapp/screens/ApplicationList.cpp displayapp/screens/ApplicationList.cpp
displayapp/screens/Notifications.cpp displayapp/screens/Notifications.cpp
displayapp/screens/Notifications_swscroll.cpp
main.cpp main.cpp
drivers/St7789.cpp drivers/St7789.cpp
drivers/SpiNorFlash.cpp drivers/SpiNorFlash.cpp
@ -421,6 +422,7 @@ set(INCLUDE_FILES
displayapp/screens/ApplicationList.h displayapp/screens/ApplicationList.h
displayapp/Apps.h displayapp/Apps.h
displayapp/screens/Notifications.h displayapp/screens/Notifications.h
displayapp/screens/Notifications_swscroll.h.h
drivers/St7789.h drivers/St7789.h
drivers/SpiNorFlash.h drivers/SpiNorFlash.h
drivers/SpiMaster.h drivers/SpiMaster.h
@ -749,7 +751,6 @@ elseif (USE_OPENOCD)
COMMENT "flashing ${EXECUTABLE_NAME}.hex" COMMENT "flashing ${EXECUTABLE_NAME}.hex"
) )
else () else ()
message()
add_custom_target(FLASH_ERASE add_custom_target(FLASH_ERASE
COMMAND ${OPENOCD_BIN_PATH} -f interface/stlink.cfg -c 'transport select hla_swd' -f target/nrf52.cfg -c init -c halt -c 'nrf5 mass_erase' -c reset -c shutdown COMMAND ${OPENOCD_BIN_PATH} -f interface/stlink.cfg -c 'transport select hla_swd' -f target/nrf52.cfg -c init -c halt -c 'nrf5 mass_erase' -c reset -c shutdown
COMMENT "erasing flashing" COMMENT "erasing flashing"

View file

@ -2,6 +2,6 @@
namespace Pinetime { namespace Pinetime {
namespace Applications { namespace Applications {
enum class Apps {None, Launcher, Clock, SysInfo, Meter, Gauge, Brightness, Music, FirmwareValidation, Paint, Notifications}; enum class Apps {None, Launcher, Clock, SysInfo, Meter, Gauge, Brightness, Music, FirmwareValidation, Paint, Notifications, Notifications2};
} }
} }

View file

@ -9,6 +9,7 @@
#include "components/datetime/DateTimeController.h" #include "components/datetime/DateTimeController.h"
#include <drivers/Cst816s.h> #include <drivers/Cst816s.h>
#include "displayapp/screens/Notifications.h" #include "displayapp/screens/Notifications.h"
#include "displayapp/screens/Notifications_swscroll.h"
#include "displayapp/screens/Tile.h" #include "displayapp/screens/Tile.h"
#include "displayapp/screens/Meter.h" #include "displayapp/screens/Meter.h"
#include "displayapp/screens/Gauge.h" #include "displayapp/screens/Gauge.h"
@ -204,6 +205,7 @@ void DisplayApp::RunningState() {
case Apps::Music : currentScreen.reset(new Screens::Music(this, systemTask.nimble().music())); break; case Apps::Music : currentScreen.reset(new Screens::Music(this, systemTask.nimble().music())); break;
case Apps::FirmwareValidation: currentScreen.reset(new Screens::FirmwareValidation(this, validator)); break; case Apps::FirmwareValidation: currentScreen.reset(new Screens::FirmwareValidation(this, validator)); break;
case Apps::Notifications: currentScreen.reset(new Screens::Notifications(this)); break; case Apps::Notifications: currentScreen.reset(new Screens::Notifications(this)); break;
case Apps::Notifications2: currentScreen.reset(new Screens::Notifications2(this)); break;
} }
nextApp = Apps::None; nextApp = Apps::None;
} }

View file

@ -59,7 +59,7 @@ std::unique_ptr<Screen> ApplicationList::CreateScreen2() {
{Symbols::asterisk, Apps::Meter}, {Symbols::asterisk, Apps::Meter},
{Symbols::paintbrush, Apps::Paint}, {Symbols::paintbrush, Apps::Paint},
{Symbols::shoe, Apps::Notifications}, {Symbols::shoe, Apps::Notifications},
{Symbols::none, Apps::None}, {Symbols::shoe, Apps::Notifications2},
{Symbols::none, Apps::None} {Symbols::none, Apps::None}
} }
}; };

View file

@ -1,12 +1,16 @@
#include "Notifications.h"
#include "displayapp/DisplayApp.h"
#include <libs/lvgl/lvgl.h> #include <libs/lvgl/lvgl.h>
#include <displayapp/DisplayApp.h>
#include <functional>
#include "Notifications.h"
using namespace Pinetime::Applications::Screens; using namespace Pinetime::Applications::Screens;
Notifications::Notifications(DisplayApp* app) : Screen(app) { Notifications::Notifications(DisplayApp* app) : Screen(app), screens{app, {
[this]() -> std::unique_ptr<Screen> { return CreateScreen1(); },
[this]() -> std::unique_ptr<Screen> { return CreateScreen2(); },
[this]() -> std::unique_ptr<Screen> { return CreateScreen3(); }
}
} {
app->SetTouchMode(DisplayApp::TouchModes::Polling);
} }
Notifications::~Notifications() { Notifications::~Notifications() {
@ -14,132 +18,196 @@ Notifications::~Notifications() {
} }
bool Notifications::Refresh() { bool Notifications::Refresh() {
screens.Refresh();
return running; return running;
} }
void Notifications::OnObjectEvent(lv_obj_t *obj, lv_event_t event, uint32_t buttonId) { bool Notifications::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
return screens.OnTouchEvent(event);
} }
bool Notifications::OnTouchEvent(Pinetime::Applications::TouchEvents event) { return true; }
bool Notifications::OnButtonPushed() { bool Notifications::OnButtonPushed() {
app->StartApp(Apps::Clock);
running = false; running = false;
return true; return true;
} }
std::unique_ptr<Screen> Notifications::CreateScreen1() {
return std::unique_ptr<Screen>(new Notifications::NotificationItem(app, "Message", "Marcel Pickett: Did you bring your ticket?", "Shot notif", "Short text", 1, 3));
}
Notifications::ListWidget::ListWidget() { std::unique_ptr<Screen> Notifications::CreateScreen2() {
static lv_point_t valid_pos[] = {{0,0}, {0,1}}; return std::unique_ptr<Screen>(new Notifications::NotificationItem(app, "Alarm", "Missed: 09:30", 2, 3));
page = lv_tileview_create(lv_scr_act(), NULL); }
lv_obj_set_size(page, LV_HOR_RES, LV_VER_RES);
lv_obj_align(page, NULL, LV_ALIGN_CENTER, 0, 0);
lv_tileview_set_valid_positions(page, valid_pos, 2);
static lv_style_t pageStyle; std::unique_ptr<Screen> Notifications::CreateScreen3() {
lv_style_copy(&pageStyle, lv_tileview_get_style(page, LV_TILEVIEW_STYLE_MAIN)); return std::unique_ptr<Screen>(new Notifications::NotificationItem(app, "Spotify", "Now playing: Bame game - Kanye West", 3, 3));
}
lv_tileview_set_style(page, LV_TILEVIEW_STYLE_MAIN, &pageStyle); Notifications::NotificationItem::NotificationItem(Pinetime::Applications::DisplayApp *app, const char *title, const char* msg, uint8_t notifNr, uint8_t notifNb) :
Screen(app), notifNr{notifNr}, notifNb{notifNb} {
lv_obj_t* container1 = lv_cont_create(lv_scr_act(), NULL);
lv_obj_t* container1 = lv_cont_create(page, NULL);
static lv_style_t contStyle; static lv_style_t contStyle;
lv_style_copy(&contStyle, lv_cont_get_style(container1, LV_CONT_STYLE_MAIN)); lv_style_copy(&contStyle, lv_cont_get_style(container1, LV_CONT_STYLE_MAIN));
contStyle.body.padding.inner = 20; contStyle.body.padding.inner = 20;
lv_cont_set_style(container1, LV_CONT_STYLE_MAIN, &contStyle); lv_cont_set_style(container1, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container1, LV_HOR_RES); lv_obj_set_width(container1, LV_HOR_RES);
lv_obj_set_height(container1, LV_VER_RES);
lv_obj_set_pos(container1, 0, 0); lv_obj_set_pos(container1, 0, 0);
lv_cont_set_layout(container1, LV_LAYOUT_COL_M); lv_cont_set_layout(container1, LV_LAYOUT_OFF);
lv_cont_set_fit2(container1, LV_FIT_FLOOD, LV_FIT_TIGHT); lv_cont_set_fit2(container1, LV_FIT_FLOOD, LV_FIT_FLOOD);
lv_tileview_add_element(page, container1);
lv_obj_t* t1 = lv_label_create(container1, NULL); lv_obj_t* t1 = lv_label_create(container1, NULL);
static lv_style_t titleStyle; static lv_style_t titleStyle;
static lv_style_t textStyle; static lv_style_t textStyle;
static lv_style_t bottomStyle;
lv_style_copy(&titleStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN)); lv_style_copy(&titleStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
lv_style_copy(&textStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN)); lv_style_copy(&textStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
lv_style_copy(&bottomStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
//titleStyle.body.main_color = LV_COLOR_RED;
//titleStyle.body.grad_color = LV_COLOR_RED;
titleStyle.body.padding.inner = 5; titleStyle.body.padding.inner = 5;
//textStyle.body.main_color = LV_COLOR_BLUE;
//textStyle.body.grad_color = LV_COLOR_BLUE;
textStyle.body.padding.inner = 5; textStyle.body.padding.inner = 5;
titleStyle.body.grad_color = LV_COLOR_GRAY;
titleStyle.body.main_color = LV_COLOR_GRAY;
textStyle.body.border.part = LV_BORDER_NONE;
//bottomStyle.body.padding.inner = 5;
bottomStyle.body.main_color = LV_COLOR_GREEN;
bottomStyle.body.grad_color = LV_COLOR_GREEN;
bottomStyle.body.border.part = LV_BORDER_TOP;
bottomStyle.body.border.color = LV_COLOR_RED;
lv_label_set_style(t1, LV_LABEL_STYLE_MAIN, &titleStyle); lv_label_set_style(t1, LV_LABEL_STYLE_MAIN, &titleStyle);
lv_label_set_long_mode(t1, LV_LABEL_LONG_BREAK); lv_label_set_long_mode(t1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t1, true); lv_label_set_body_draw(t1, true);
lv_obj_set_width(t1, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) ); lv_obj_set_width(t1, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t1, "Message"); lv_label_set_text(t1, title);
lv_obj_set_pos(t1, titleStyle.body.padding.left, titleStyle.body.padding.top);
auto titleHeight = lv_obj_get_height(t1);
lv_obj_t* l1 = lv_label_create(container1, NULL); lv_obj_t* l1 = lv_label_create(container1, NULL);
lv_label_set_style(l1, LV_PAGE_STYLE_BG, &textStyle); lv_label_set_style(l1, LV_LABEL_STYLE_MAIN, &textStyle);
lv_obj_set_pos(l1, textStyle.body.padding.left, titleHeight + titleStyle.body.padding.bottom + textStyle.body.padding.bottom + textStyle.body.padding.top);
lv_label_set_long_mode(l1, LV_LABEL_LONG_BREAK); lv_label_set_long_mode(l1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l1, true); lv_label_set_body_draw(l1, true);
lv_obj_set_width(l1, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) ); lv_obj_set_width(l1, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l1, "Marcel Pickett: Did you bring your ticket?"); lv_label_set_text(l1, msg);
/*---*/ lv_obj_t* bottomlabel = lv_label_create(container1, NULL);
lv_obj_t* container2 = lv_cont_create(page, NULL); lv_label_set_style(bottomlabel, LV_LABEL_STYLE_MAIN, &bottomStyle);
lv_obj_set_width(bottomlabel, LV_HOR_RES - (bottomStyle.body.padding.left + bottomStyle.body.padding.right) );
snprintf(pageText, 4, "%d/%d", notifNr, notifNb);
lv_label_set_text(bottomlabel, pageText);
auto bottomHeight = lv_obj_get_height(bottomlabel);
lv_obj_set_pos(bottomlabel, 0, LV_VER_RES - (bottomHeight*2));
}
Notifications::NotificationItem::NotificationItem(Pinetime::Applications::DisplayApp *app, const char *title1, const char* msg1, const char *title2, const char* msg2, uint8_t notifNr, uint8_t notifNb) :
Screen(app), notifNr{notifNr}, notifNb{notifNb} {
lv_obj_t* container1 = lv_cont_create(lv_scr_act(), NULL);
static lv_style_t contStyle;
lv_style_copy(&contStyle, lv_cont_get_style(container1, LV_CONT_STYLE_MAIN));
contStyle.body.padding.inner = 20;
lv_cont_set_style(container1, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container1, LV_HOR_RES);
lv_obj_set_height(container1, LV_VER_RES);
lv_obj_set_pos(container1, 0, 0);
lv_cont_set_layout(container1, LV_LAYOUT_OFF);
lv_cont_set_fit2(container1, LV_FIT_FLOOD, LV_FIT_FLOOD);
lv_obj_t* t1 = lv_label_create(container1, NULL);
static lv_style_t titleStyle;
static lv_style_t textStyle;
static lv_style_t bottomStyle;
lv_style_copy(&titleStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
lv_style_copy(&textStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
lv_style_copy(&bottomStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
titleStyle.body.padding.inner = 5;
textStyle.body.padding.inner = 5;
titleStyle.body.grad_color = LV_COLOR_GRAY;
titleStyle.body.main_color = LV_COLOR_GRAY;
textStyle.body.border.part = LV_BORDER_NONE;
//bottomStyle.body.padding.inner = 5;
bottomStyle.body.main_color = LV_COLOR_GREEN;
bottomStyle.body.grad_color = LV_COLOR_GREEN;
bottomStyle.body.border.part = LV_BORDER_TOP;
bottomStyle.body.border.color = LV_COLOR_RED;
lv_label_set_style(t1, LV_LABEL_STYLE_MAIN, &titleStyle);
lv_label_set_long_mode(t1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t1, true);
lv_obj_set_width(t1, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t1, title1);
lv_obj_set_pos(t1, titleStyle.body.padding.left, titleStyle.body.padding.top);
auto titleHeight = lv_obj_get_height(t1);
lv_obj_t* l1 = lv_label_create(container1, NULL);
lv_label_set_style(l1, LV_LABEL_STYLE_MAIN, &textStyle);
lv_obj_set_pos(l1, textStyle.body.padding.left, titleHeight + titleStyle.body.padding.bottom + textStyle.body.padding.bottom + textStyle.body.padding.top);
lv_label_set_long_mode(l1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l1, true);
lv_obj_set_width(l1, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l1, msg1);
auto bottomPos = lv_obj_get_y(l1) + lv_obj_get_height(l1) + textStyle.body.padding.bottom;
/*
lv_obj_t* bottomlabel = lv_label_create(container1, NULL);
lv_label_set_style(bottomlabel, LV_LABEL_STYLE_MAIN, &bottomStyle);
lv_obj_set_width(bottomlabel, LV_HOR_RES - (bottomStyle.body.padding.left + bottomStyle.body.padding.right) );
snprintf(pageText, 4, "%d/%d", notifNr, notifNb);
lv_label_set_text(bottomlabel, pageText);
auto bottomHeight = lv_obj_get_height(bottomlabel);
lv_obj_set_pos(bottomlabel, 0, LV_VER_RES - (bottomHeight*2));
*/
//-------------------------------------------------
/*
lv_obj_t* container2 = lv_cont_create(lv_scr_act(), NULL);
lv_cont_set_style(container2, LV_CONT_STYLE_MAIN, &contStyle); lv_cont_set_style(container2, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container2, LV_HOR_RES); lv_obj_set_width(container2, LV_HOR_RES);
lv_obj_set_pos(container2, 0, lv_obj_get_y(container1) + lv_obj_get_height(container1)+5); lv_obj_set_height(container2, LV_VER_RES - bottomPos);
lv_cont_set_layout(container2, LV_LAYOUT_COL_M); lv_obj_set_pos(container2, 0, bottomPos);
lv_cont_set_fit2(container2, LV_FIT_FLOOD, LV_FIT_TIGHT); lv_cont_set_layout(container2, LV_LAYOUT_OFF);
lv_tileview_add_element(page, container2); lv_cont_set_fit2(container2, LV_FIT_FLOOD, LV_FIT_FLOOD);
*/
lv_obj_t* t2 = lv_label_create(container1, NULL);
lv_obj_t* t2 = lv_label_create(container2, NULL);
lv_label_set_style(t2, LV_PAGE_STYLE_BG, &titleStyle); lv_label_set_style(t2, LV_LABEL_STYLE_MAIN, &titleStyle);
lv_label_set_long_mode(t2, LV_LABEL_LONG_BREAK); lv_label_set_long_mode(t2, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t2, true); lv_label_set_body_draw(t2, true);
lv_obj_set_width(t2, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) ); lv_obj_set_width(t2, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t2, "Alarm"); lv_label_set_text(t2, title2);
lv_obj_set_pos(t2, titleStyle.body.padding.left, bottomPos + titleStyle.body.padding.top);
auto title2Height = lv_obj_get_height(t2);
lv_obj_t* l2 = lv_label_create(container1, NULL);
lv_label_set_style(l2, LV_LABEL_STYLE_MAIN, &textStyle);
lv_obj_set_pos(l2, textStyle.body.padding.left, bottomPos + title2Height + titleStyle.body.padding.bottom + textStyle.body.padding.bottom + textStyle.body.padding.top);
lv_obj_t* l2 = lv_label_create(container2, NULL);
lv_label_set_style(l2, LV_PAGE_STYLE_BG, &textStyle);
lv_label_set_long_mode(l2, LV_LABEL_LONG_BREAK); lv_label_set_long_mode(l2, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l2, true); lv_label_set_body_draw(l2, true);
lv_obj_set_width(l2, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) ); lv_obj_set_width(l2, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l2, "Missed: 09:30"); lv_label_set_text(l2, msg2);
/*****/
lv_obj_t* container3 = lv_cont_create(page, NULL);
lv_cont_set_style(container3, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container3, LV_HOR_RES);
lv_obj_set_pos(container3, 0, lv_obj_get_y(container2) + lv_obj_get_height(container2)+5);
lv_cont_set_layout(container3, LV_LAYOUT_COL_M);
lv_cont_set_fit2(container3, LV_FIT_FLOOD, LV_FIT_TIGHT);
lv_tileview_add_element(page, container3);
lv_obj_t* t3 = lv_label_create(container3, NULL);
lv_label_set_style(t3, LV_PAGE_STYLE_BG, &titleStyle);
lv_label_set_long_mode(t3, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t3, true);
lv_obj_set_width(t3, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t3, "Spotify");
lv_obj_t* l3 = lv_label_create(container3, NULL);
lv_label_set_style(l3, LV_PAGE_STYLE_BG, &textStyle);
lv_label_set_long_mode(l3, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l3, true);
lv_obj_set_width(l3, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l3, "Now playing: Bame game - Kanye West");
} }
Notifications::NotificationItem::~NotificationItem() {
lv_obj_clean(lv_scr_act());
}

View file

@ -1,11 +1,11 @@
#pragma once #pragma once
#include <cstdint> #include <functional>
#include <vector>
#include "Screen.h" #include "Screen.h"
#include <bits/unique_ptr.h> #include "ScreenList.h"
#include "Modal.h"
#include <lvgl/src/lv_core/lv_style.h>
#include <displayapp/Apps.h>
namespace Pinetime { namespace Pinetime {
namespace Applications { namespace Applications {
@ -17,19 +17,27 @@ namespace Pinetime {
bool Refresh() override; bool Refresh() override;
bool OnButtonPushed() override; bool OnButtonPushed() override;
void OnObjectEvent(lv_obj_t* obj, lv_event_t event, uint32_t buttonId);
bool OnTouchEvent(Pinetime::Applications::TouchEvents event) override; bool OnTouchEvent(Pinetime::Applications::TouchEvents event) override;
private: private:
class ListWidget { ScreenList<3> screens;
public:
ListWidget();
private:
lv_obj_t* page = nullptr;
};
bool running = true; bool running = true;
ListWidget list; std::unique_ptr<Screen> CreateScreen1();
std::unique_ptr<Screen> CreateScreen2();
std::unique_ptr<Screen> CreateScreen3();
class NotificationItem : public Screen {
public:
NotificationItem(DisplayApp* app, const char* title, const char* msg, uint8_t notifNr, uint8_t notifNb);
NotificationItem(DisplayApp* app, const char* title1, const char* msg1, const char* title2, const char* msg2, uint8_t notifNr, uint8_t notifNb);
~NotificationItem() override;
bool Refresh() override {return false;}
private:
uint8_t notifNr = 0;
uint8_t notifNb = 0;
char pageText[4];
};
}; };
} }
} }

View file

@ -0,0 +1,145 @@
#include "Notifications_swscroll.h"
#include "displayapp/DisplayApp.h"
#include <libs/lvgl/lvgl.h>
using namespace Pinetime::Applications::Screens;
Notifications2::Notifications2(DisplayApp* app) : Screen(app) {
app->SetTouchMode(DisplayApp::TouchModes::Polling);
}
Notifications2::~Notifications2() {
lv_obj_clean(lv_scr_act());
}
bool Notifications2::Refresh() {
return running;
}
void Notifications2::OnObjectEvent(lv_obj_t *obj, lv_event_t event, uint32_t buttonId) {
}
bool Notifications2::OnTouchEvent(Pinetime::Applications::TouchEvents event) { return true; }
bool Notifications2::OnButtonPushed() {
app->StartApp(Apps::Clock);
running = false;
return true;
}
Notifications2::ListWidget::ListWidget() {
static lv_point_t valid_pos[] = {{0,0}, {0,1}};
page = lv_tileview_create(lv_scr_act(), NULL);
lv_obj_set_size(page, LV_HOR_RES, LV_VER_RES);
lv_obj_align(page, NULL, LV_ALIGN_CENTER, 0, 0);
lv_tileview_set_valid_positions(page, valid_pos, 2);
static lv_style_t pageStyle;
lv_style_copy(&pageStyle, lv_tileview_get_style(page, LV_TILEVIEW_STYLE_MAIN));
lv_tileview_set_style(page, LV_TILEVIEW_STYLE_MAIN, &pageStyle);
lv_obj_t* container1 = lv_cont_create(page, NULL);
static lv_style_t contStyle;
lv_style_copy(&contStyle, lv_cont_get_style(container1, LV_CONT_STYLE_MAIN));
contStyle.body.padding.inner = 20;
lv_cont_set_style(container1, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container1, LV_HOR_RES);
lv_obj_set_pos(container1, 0, 0);
lv_cont_set_layout(container1, LV_LAYOUT_COL_M);
lv_cont_set_fit2(container1, LV_FIT_FLOOD, LV_FIT_TIGHT);
lv_tileview_add_element(page, container1);
lv_obj_t* t1 = lv_label_create(container1, NULL);
static lv_style_t titleStyle;
static lv_style_t textStyle;
lv_style_copy(&titleStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
lv_style_copy(&textStyle, lv_label_get_style(t1, LV_LABEL_STYLE_MAIN));
//titleStyle.body.main_color = LV_COLOR_RED;
//titleStyle.body.grad_color = LV_COLOR_RED;
titleStyle.body.padding.inner = 5;
//textStyle.body.main_color = LV_COLOR_BLUE;
//textStyle.body.grad_color = LV_COLOR_BLUE;
textStyle.body.padding.inner = 5;
lv_label_set_style(t1, LV_LABEL_STYLE_MAIN, &titleStyle);
lv_label_set_long_mode(t1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t1, true);
lv_obj_set_width(t1, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t1, "Message");
lv_obj_t* l1 = lv_label_create(container1, NULL);
lv_label_set_style(l1, LV_PAGE_STYLE_BG, &textStyle);
lv_label_set_long_mode(l1, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l1, true);
lv_obj_set_width(l1, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l1, "Marcel Pickett: Did you bring your ticket?");
/*---*/
lv_obj_t* container2 = lv_cont_create(page, NULL);
lv_cont_set_style(container2, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container2, LV_HOR_RES);
lv_obj_set_pos(container2, 0, lv_obj_get_y(container1) + lv_obj_get_height(container1)+5);
lv_cont_set_layout(container2, LV_LAYOUT_COL_M);
lv_cont_set_fit2(container2, LV_FIT_FLOOD, LV_FIT_TIGHT);
lv_tileview_add_element(page, container2);
lv_obj_t* t2 = lv_label_create(container2, NULL);
lv_label_set_style(t2, LV_PAGE_STYLE_BG, &titleStyle);
lv_label_set_long_mode(t2, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t2, true);
lv_obj_set_width(t2, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t2, "Alarm");
lv_obj_t* l2 = lv_label_create(container2, NULL);
lv_label_set_style(l2, LV_PAGE_STYLE_BG, &textStyle);
lv_label_set_long_mode(l2, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l2, true);
lv_obj_set_width(l2, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l2, "Missed: 09:30");
/*****/
lv_obj_t* container3 = lv_cont_create(page, NULL);
lv_cont_set_style(container3, LV_CONT_STYLE_MAIN, &contStyle);
lv_obj_set_width(container3, LV_HOR_RES);
lv_obj_set_pos(container3, 0, lv_obj_get_y(container2) + lv_obj_get_height(container2)+5);
lv_cont_set_layout(container3, LV_LAYOUT_COL_M);
lv_cont_set_fit2(container3, LV_FIT_FLOOD, LV_FIT_TIGHT);
lv_tileview_add_element(page, container3);
lv_obj_t* t3 = lv_label_create(container3, NULL);
lv_label_set_style(t3, LV_PAGE_STYLE_BG, &titleStyle);
lv_label_set_long_mode(t3, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(t3, true);
lv_obj_set_width(t3, LV_HOR_RES - (titleStyle.body.padding.left + titleStyle.body.padding.right) );
lv_label_set_text(t3, "Spotify");
lv_obj_t* l3 = lv_label_create(container3, NULL);
lv_label_set_style(l3, LV_PAGE_STYLE_BG, &textStyle);
lv_label_set_long_mode(l3, LV_LABEL_LONG_BREAK);
lv_label_set_body_draw(l3, true);
lv_obj_set_width(l3, LV_HOR_RES - (textStyle.body.padding.left + textStyle.body.padding.right) );
lv_label_set_text(l3, "Now playing: Bame game - Kanye West");
}

View file

@ -0,0 +1,36 @@
#pragma once
#include <cstdint>
#include "Screen.h"
#include <bits/unique_ptr.h>
#include "Modal.h"
#include <lvgl/src/lv_core/lv_style.h>
#include <displayapp/Apps.h>
namespace Pinetime {
namespace Applications {
namespace Screens {
class Notifications2 : public Screen {
public:
explicit Notifications2(DisplayApp* app);
~Notifications2() override;
bool Refresh() override;
bool OnButtonPushed() override;
void OnObjectEvent(lv_obj_t* obj, lv_event_t event, uint32_t buttonId);
bool OnTouchEvent(Pinetime::Applications::TouchEvents event) override;
private:
class ListWidget {
public:
ListWidget();
private:
lv_obj_t* page = nullptr;
};
bool running = true;
ListWidget list;
};
}
}
}