Setting SetDate/SetTime : replace #defines by constexpr variables, NULL by nullptr and other small cleanings.
This commit is contained in:
parent
7cbd56896a
commit
f2357b36e5
|
@ -5,33 +5,31 @@
|
||||||
#include "displayapp/DisplayApp.h"
|
#include "displayapp/DisplayApp.h"
|
||||||
#include "displayapp/screens/Symbols.h"
|
#include "displayapp/screens/Symbols.h"
|
||||||
|
|
||||||
#define POS_X_DAY -72
|
|
||||||
#define POS_X_MONTH 0
|
|
||||||
#define POS_X_YEAR 72
|
|
||||||
#define POS_Y_PLUS -50
|
|
||||||
#define POS_Y_TEXT -6
|
|
||||||
#define POS_Y_MINUS 40
|
|
||||||
|
|
||||||
using namespace Pinetime::Applications::Screens;
|
using namespace Pinetime::Applications::Screens;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
static void event_handler(lv_obj_t * obj, lv_event_t event) {
|
constexpr int16_t POS_X_DAY = -72;
|
||||||
SettingSetDate* screen = static_cast<SettingSetDate *>(obj->user_data);
|
constexpr int16_t POS_X_MONTH = 0;
|
||||||
|
constexpr int16_t POS_X_YEAR = 72;
|
||||||
|
constexpr int16_t POS_Y_PLUS = -50;
|
||||||
|
constexpr int16_t POS_Y_TEXT = -6;
|
||||||
|
constexpr int16_t POS_Y_MINUS = 40;
|
||||||
|
|
||||||
|
void event_handler(lv_obj_t * obj, lv_event_t event) {
|
||||||
|
auto* screen = static_cast<SettingSetDate *>(obj->user_data);
|
||||||
screen->HandleButtonPress(obj, event);
|
screen->HandleButtonPress(obj, event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SettingSetDate::SettingSetDate(
|
SettingSetDate::SettingSetDate(Pinetime::Applications::DisplayApp *app, Pinetime::Controllers::DateTime &dateTimeController) :
|
||||||
Pinetime::Applications::DisplayApp *app, Pinetime::Controllers::DateTime &dateTimeController) :
|
|
||||||
Screen(app),
|
Screen(app),
|
||||||
dateTimeController {dateTimeController}
|
dateTimeController {dateTimeController} {
|
||||||
{
|
lv_obj_t * title = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_t * title = lv_label_create(lv_scr_act(), NULL);
|
|
||||||
lv_label_set_text_static(title, "Set current date");
|
lv_label_set_text_static(title, "Set current date");
|
||||||
lv_label_set_align(title, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(title, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15);
|
lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15);
|
||||||
|
|
||||||
lv_obj_t * icon = lv_label_create(lv_scr_act(), NULL);
|
lv_obj_t * icon = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE);
|
lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE);
|
||||||
|
|
||||||
lv_label_set_text_static(icon, Symbols::clock);
|
lv_label_set_text_static(icon, Symbols::clock);
|
||||||
|
@ -39,14 +37,14 @@ SettingSetDate::SettingSetDate(
|
||||||
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
|
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
|
||||||
|
|
||||||
dayValue = static_cast<int>(dateTimeController.Day());
|
dayValue = static_cast<int>(dateTimeController.Day());
|
||||||
lblDay = lv_label_create(lv_scr_act(), NULL);
|
lblDay = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
||||||
lv_label_set_align(lblDay, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblDay, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblDay, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_TEXT);
|
lv_obj_align(lblDay, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_TEXT);
|
||||||
lv_obj_set_auto_realign(lblDay, true);
|
lv_obj_set_auto_realign(lblDay, true);
|
||||||
|
|
||||||
monthValue = static_cast<int>(dateTimeController.Month());
|
monthValue = static_cast<int>(dateTimeController.Month());
|
||||||
lblMonth = lv_label_create(lv_scr_act(), NULL);
|
lblMonth = lv_label_create(lv_scr_act(), nullptr);
|
||||||
UpdateMonthLabel();
|
UpdateMonthLabel();
|
||||||
lv_label_set_align(lblMonth, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblMonth, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblMonth, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_TEXT);
|
lv_obj_align(lblMonth, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_TEXT);
|
||||||
|
@ -55,55 +53,55 @@ SettingSetDate::SettingSetDate(
|
||||||
yearValue = static_cast<int>(dateTimeController.Year());
|
yearValue = static_cast<int>(dateTimeController.Year());
|
||||||
if (yearValue < 2021)
|
if (yearValue < 2021)
|
||||||
yearValue = 2021;
|
yearValue = 2021;
|
||||||
lblYear = lv_label_create(lv_scr_act(), NULL);
|
lblYear = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
||||||
lv_label_set_align(lblYear, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblYear, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblYear, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_TEXT);
|
lv_obj_align(lblYear, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_TEXT);
|
||||||
lv_obj_set_auto_realign(lblYear, true);
|
lv_obj_set_auto_realign(lblYear, true);
|
||||||
|
|
||||||
btnDayPlus = lv_btn_create(lv_scr_act(), NULL);
|
btnDayPlus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnDayPlus->user_data = this;
|
btnDayPlus->user_data = this;
|
||||||
lv_obj_set_size(btnDayPlus, 50, 40);
|
lv_obj_set_size(btnDayPlus, 50, 40);
|
||||||
lv_obj_align(btnDayPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_PLUS);
|
lv_obj_align(btnDayPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_PLUS);
|
||||||
lv_obj_set_style_local_value_str(btnDayPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
lv_obj_set_style_local_value_str(btnDayPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
||||||
lv_obj_set_event_cb(btnDayPlus, event_handler);
|
lv_obj_set_event_cb(btnDayPlus, event_handler);
|
||||||
|
|
||||||
btnDayMinus = lv_btn_create(lv_scr_act(), NULL);
|
btnDayMinus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnDayMinus->user_data = this;
|
btnDayMinus->user_data = this;
|
||||||
lv_obj_set_size(btnDayMinus, 50, 40);
|
lv_obj_set_size(btnDayMinus, 50, 40);
|
||||||
lv_obj_align(btnDayMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_MINUS);
|
lv_obj_align(btnDayMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_DAY, POS_Y_MINUS);
|
||||||
lv_obj_set_style_local_value_str(btnDayMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
lv_obj_set_style_local_value_str(btnDayMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
||||||
lv_obj_set_event_cb(btnDayMinus, event_handler);
|
lv_obj_set_event_cb(btnDayMinus, event_handler);
|
||||||
|
|
||||||
btnMonthPlus = lv_btn_create(lv_scr_act(), NULL);
|
btnMonthPlus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnMonthPlus->user_data = this;
|
btnMonthPlus->user_data = this;
|
||||||
lv_obj_set_size(btnMonthPlus, 50, 40);
|
lv_obj_set_size(btnMonthPlus, 50, 40);
|
||||||
lv_obj_align(btnMonthPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_PLUS);
|
lv_obj_align(btnMonthPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_PLUS);
|
||||||
lv_obj_set_style_local_value_str(btnMonthPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
lv_obj_set_style_local_value_str(btnMonthPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
||||||
lv_obj_set_event_cb(btnMonthPlus, event_handler);
|
lv_obj_set_event_cb(btnMonthPlus, event_handler);
|
||||||
|
|
||||||
btnMonthMinus = lv_btn_create(lv_scr_act(), NULL);
|
btnMonthMinus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnMonthMinus->user_data = this;
|
btnMonthMinus->user_data = this;
|
||||||
lv_obj_set_size(btnMonthMinus, 50, 40);
|
lv_obj_set_size(btnMonthMinus, 50, 40);
|
||||||
lv_obj_align(btnMonthMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_MINUS);
|
lv_obj_align(btnMonthMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MONTH, POS_Y_MINUS);
|
||||||
lv_obj_set_style_local_value_str(btnMonthMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
lv_obj_set_style_local_value_str(btnMonthMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
||||||
lv_obj_set_event_cb(btnMonthMinus, event_handler);
|
lv_obj_set_event_cb(btnMonthMinus, event_handler);
|
||||||
|
|
||||||
btnYearPlus = lv_btn_create(lv_scr_act(), NULL);
|
btnYearPlus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnYearPlus->user_data = this;
|
btnYearPlus->user_data = this;
|
||||||
lv_obj_set_size(btnYearPlus, 50, 40);
|
lv_obj_set_size(btnYearPlus, 50, 40);
|
||||||
lv_obj_align(btnYearPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_PLUS);
|
lv_obj_align(btnYearPlus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_PLUS);
|
||||||
lv_obj_set_style_local_value_str(btnYearPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
lv_obj_set_style_local_value_str(btnYearPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
||||||
lv_obj_set_event_cb(btnYearPlus, event_handler);
|
lv_obj_set_event_cb(btnYearPlus, event_handler);
|
||||||
|
|
||||||
btnYearMinus = lv_btn_create(lv_scr_act(), NULL);
|
btnYearMinus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnYearMinus->user_data = this;
|
btnYearMinus->user_data = this;
|
||||||
lv_obj_set_size(btnYearMinus, 50, 40);
|
lv_obj_set_size(btnYearMinus, 50, 40);
|
||||||
lv_obj_align(btnYearMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_MINUS);
|
lv_obj_align(btnYearMinus, lv_scr_act(), LV_ALIGN_CENTER, POS_X_YEAR, POS_Y_MINUS);
|
||||||
lv_obj_set_style_local_value_str(btnYearMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
lv_obj_set_style_local_value_str(btnYearMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
||||||
lv_obj_set_event_cb(btnYearMinus, event_handler);
|
lv_obj_set_event_cb(btnYearMinus, event_handler);
|
||||||
|
|
||||||
btnSetTime = lv_btn_create(lv_scr_act(), NULL);
|
btnSetTime = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnSetTime->user_data = this;
|
btnSetTime->user_data = this;
|
||||||
lv_obj_set_size(btnSetTime, 120, 48);
|
lv_obj_set_size(btnSetTime, 120, 48);
|
||||||
lv_obj_align(btnSetTime, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
lv_obj_align(btnSetTime, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
||||||
|
@ -116,7 +114,6 @@ SettingSetDate::~SettingSetDate() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingSetDate::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
void SettingSetDate::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
||||||
|
|
||||||
if (event != LV_EVENT_CLICKED)
|
if (event != LV_EVENT_CLICKED)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -126,43 +123,37 @@ void SettingSetDate::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
||||||
dayValue = 1;
|
dayValue = 1;
|
||||||
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnDayMinus) {
|
||||||
else if (object == btnDayMinus) {
|
|
||||||
dayValue--;
|
dayValue--;
|
||||||
if (dayValue < 1)
|
if (dayValue < 1)
|
||||||
dayValue = MaximumDayOfMonth();
|
dayValue = MaximumDayOfMonth();
|
||||||
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
lv_label_set_text_fmt(lblDay, "%d", dayValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnMonthPlus) {
|
||||||
else if (object == btnMonthPlus) {
|
|
||||||
monthValue++;
|
monthValue++;
|
||||||
if (monthValue > 12)
|
if (monthValue > 12)
|
||||||
monthValue = 1;
|
monthValue = 1;
|
||||||
UpdateMonthLabel();
|
UpdateMonthLabel();
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
CheckDay();
|
CheckDay();
|
||||||
}
|
} else if (object == btnMonthMinus) {
|
||||||
else if (object == btnMonthMinus) {
|
|
||||||
monthValue--;
|
monthValue--;
|
||||||
if (monthValue < 1)
|
if (monthValue < 1)
|
||||||
monthValue = 12;
|
monthValue = 12;
|
||||||
UpdateMonthLabel();
|
UpdateMonthLabel();
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
CheckDay();
|
CheckDay();
|
||||||
}
|
} else if (object == btnYearPlus) {
|
||||||
else if (object == btnYearPlus) {
|
|
||||||
yearValue++;
|
yearValue++;
|
||||||
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
CheckDay();
|
CheckDay();
|
||||||
}
|
} else if (object == btnYearMinus) {
|
||||||
else if (object == btnYearMinus) {
|
|
||||||
yearValue--;
|
yearValue--;
|
||||||
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
lv_label_set_text_fmt(lblYear, "%d", yearValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
CheckDay();
|
CheckDay();
|
||||||
}
|
} else if (object == btnSetTime) {
|
||||||
else if (object == btnSetTime) {
|
|
||||||
NRF_LOG_INFO("Setting date (manually) to %04d-%02d-%02d", yearValue, monthValue, dayValue);
|
NRF_LOG_INFO("Setting date (manually) to %04d-%02d-%02d", yearValue, monthValue, dayValue);
|
||||||
dateTimeController.SetTime(static_cast<uint16_t>(yearValue),
|
dateTimeController.SetTime(static_cast<uint16_t>(yearValue),
|
||||||
static_cast<uint8_t>(monthValue),
|
static_cast<uint8_t>(monthValue),
|
||||||
|
@ -202,7 +193,6 @@ void SettingSetDate::CheckDay() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingSetDate::UpdateMonthLabel() {
|
void SettingSetDate::UpdateMonthLabel() {
|
||||||
lv_label_set_text_static(lblMonth,
|
lv_label_set_text_static(
|
||||||
Pinetime::Controllers::DateTime::MonthShortToStringLow(static_cast<Pinetime::Controllers::DateTime::Months>(monthValue)));
|
lblMonth, Pinetime::Controllers::DateTime::MonthShortToStringLow(static_cast<Pinetime::Controllers::DateTime::Months>(monthValue)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,10 +6,8 @@
|
||||||
#include "displayapp/screens/Screen.h"
|
#include "displayapp/screens/Screen.h"
|
||||||
|
|
||||||
namespace Pinetime {
|
namespace Pinetime {
|
||||||
|
|
||||||
namespace Applications {
|
namespace Applications {
|
||||||
namespace Screens {
|
namespace Screens {
|
||||||
|
|
||||||
class SettingSetDate : public Screen{
|
class SettingSetDate : public Screen{
|
||||||
public:
|
public:
|
||||||
SettingSetDate(DisplayApp* app, Pinetime::Controllers::DateTime &dateTimeController);
|
SettingSetDate(DisplayApp* app, Pinetime::Controllers::DateTime &dateTimeController);
|
||||||
|
@ -18,7 +16,6 @@ namespace Pinetime {
|
||||||
void HandleButtonPress(lv_obj_t *object, lv_event_t event);
|
void HandleButtonPress(lv_obj_t *object, lv_event_t event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
Controllers::DateTime& dateTimeController;
|
Controllers::DateTime& dateTimeController;
|
||||||
|
|
||||||
int dayValue;
|
int dayValue;
|
||||||
|
|
|
@ -5,34 +5,32 @@
|
||||||
#include "displayapp/DisplayApp.h"
|
#include "displayapp/DisplayApp.h"
|
||||||
#include "displayapp/screens/Symbols.h"
|
#include "displayapp/screens/Symbols.h"
|
||||||
|
|
||||||
#define POS_X_HOURS -72
|
|
||||||
#define POS_X_MINUTES 0
|
|
||||||
#define POS_X_SECONDS 72
|
|
||||||
#define POS_Y_PLUS -50
|
|
||||||
#define POS_Y_TEXT -6
|
|
||||||
#define POS_Y_MINUS 40
|
|
||||||
#define OFS_Y_COLON -2
|
|
||||||
|
|
||||||
using namespace Pinetime::Applications::Screens;
|
using namespace Pinetime::Applications::Screens;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
static void event_handler(lv_obj_t * obj, lv_event_t event) {
|
constexpr int16_t POS_X_HOURS = -72;
|
||||||
SettingSetTime* screen = static_cast<SettingSetTime *>(obj->user_data);
|
constexpr int16_t POS_X_MINUTES = 0;
|
||||||
|
constexpr int16_t POS_X_SECONDS = 72;
|
||||||
|
constexpr int16_t POS_Y_PLUS = -50;
|
||||||
|
constexpr int16_t POS_Y_TEXT = -6;
|
||||||
|
constexpr int16_t POS_Y_MINUS = 40;
|
||||||
|
constexpr int16_t OFS_Y_COLON = -2;
|
||||||
|
|
||||||
|
void event_handler(lv_obj_t * obj, lv_event_t event) {
|
||||||
|
auto* screen = static_cast<SettingSetTime *>(obj->user_data);
|
||||||
screen->HandleButtonPress(obj, event);
|
screen->HandleButtonPress(obj, event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SettingSetTime::SettingSetTime(
|
SettingSetTime::SettingSetTime(Pinetime::Applications::DisplayApp *app, Pinetime::Controllers::DateTime &dateTimeController) :
|
||||||
Pinetime::Applications::DisplayApp *app, Pinetime::Controllers::DateTime &dateTimeController) :
|
|
||||||
Screen(app),
|
Screen(app),
|
||||||
dateTimeController {dateTimeController}
|
dateTimeController {dateTimeController} {
|
||||||
{
|
lv_obj_t * title = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_t * title = lv_label_create(lv_scr_act(), NULL);
|
|
||||||
lv_label_set_text_static(title, "Set current time");
|
lv_label_set_text_static(title, "Set current time");
|
||||||
lv_label_set_align(title, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(title, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15);
|
lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15);
|
||||||
|
|
||||||
lv_obj_t * icon = lv_label_create(lv_scr_act(), NULL);
|
lv_obj_t * icon = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE);
|
lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE);
|
||||||
|
|
||||||
lv_label_set_text_static(icon, Symbols::clock);
|
lv_label_set_text_static(icon, Symbols::clock);
|
||||||
|
@ -40,68 +38,68 @@ SettingSetTime::SettingSetTime(
|
||||||
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
|
lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
|
||||||
|
|
||||||
hoursValue = static_cast<int>(dateTimeController.Hours());
|
hoursValue = static_cast<int>(dateTimeController.Hours());
|
||||||
lblHours = lv_label_create(lv_scr_act(), NULL);
|
lblHours = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_font(lblHours, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
lv_obj_set_style_local_text_font(lblHours, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
||||||
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
||||||
lv_label_set_align(lblHours, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblHours, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblHours, lv_scr_act(), LV_ALIGN_CENTER, POS_X_HOURS, POS_Y_TEXT);
|
lv_obj_align(lblHours, lv_scr_act(), LV_ALIGN_CENTER, POS_X_HOURS, POS_Y_TEXT);
|
||||||
lv_obj_set_auto_realign(lblHours, true);
|
lv_obj_set_auto_realign(lblHours, true);
|
||||||
|
|
||||||
lv_obj_t * lblColon1 = lv_label_create(lv_scr_act(), NULL);
|
lv_obj_t * lblColon1 = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_font(lblColon1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
lv_obj_set_style_local_text_font(lblColon1, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
||||||
lv_label_set_text_static(lblColon1, ":");
|
lv_label_set_text_static(lblColon1, ":");
|
||||||
lv_label_set_align(lblColon1, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblColon1, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblColon1, lv_scr_act(), LV_ALIGN_CENTER, (POS_X_HOURS + POS_X_MINUTES) / 2, POS_Y_TEXT + OFS_Y_COLON);
|
lv_obj_align(lblColon1, lv_scr_act(), LV_ALIGN_CENTER, (POS_X_HOURS + POS_X_MINUTES) / 2, POS_Y_TEXT + OFS_Y_COLON);
|
||||||
|
|
||||||
minutesValue = static_cast<int>(dateTimeController.Minutes());
|
minutesValue = static_cast<int>(dateTimeController.Minutes());
|
||||||
lblMinutes = lv_label_create(lv_scr_act(), NULL);
|
lblMinutes = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_font(lblMinutes, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
lv_obj_set_style_local_text_font(lblMinutes, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
||||||
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
||||||
lv_label_set_align(lblMinutes, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblMinutes, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblMinutes, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MINUTES, POS_Y_TEXT);
|
lv_obj_align(lblMinutes, lv_scr_act(), LV_ALIGN_CENTER, POS_X_MINUTES, POS_Y_TEXT);
|
||||||
lv_obj_set_auto_realign(lblMinutes, true);
|
lv_obj_set_auto_realign(lblMinutes, true);
|
||||||
|
|
||||||
lv_obj_t * lblColon2 = lv_label_create(lv_scr_act(), NULL);
|
lv_obj_t * lblColon2 = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_font(lblColon2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
lv_obj_set_style_local_text_font(lblColon2, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
||||||
lv_label_set_text_static(lblColon2, ":");
|
lv_label_set_text_static(lblColon2, ":");
|
||||||
lv_label_set_align(lblColon2, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblColon2, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblColon2, lv_scr_act(), LV_ALIGN_CENTER, (POS_X_MINUTES + POS_X_SECONDS) / 2, POS_Y_TEXT + OFS_Y_COLON);
|
lv_obj_align(lblColon2, lv_scr_act(), LV_ALIGN_CENTER, (POS_X_MINUTES + POS_X_SECONDS) / 2, POS_Y_TEXT + OFS_Y_COLON);
|
||||||
|
|
||||||
lv_obj_t * lblSeconds = lv_label_create(lv_scr_act(), NULL);
|
lv_obj_t * lblSeconds = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_font(lblSeconds, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
lv_obj_set_style_local_text_font(lblSeconds, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &jetbrains_mono_42);
|
||||||
lv_label_set_text_static(lblSeconds, "00");
|
lv_label_set_text_static(lblSeconds, "00");
|
||||||
lv_label_set_align(lblSeconds, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(lblSeconds, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(lblSeconds, lv_scr_act(), LV_ALIGN_CENTER, POS_X_SECONDS, POS_Y_TEXT);
|
lv_obj_align(lblSeconds, lv_scr_act(), LV_ALIGN_CENTER, POS_X_SECONDS, POS_Y_TEXT);
|
||||||
|
|
||||||
btnHoursPlus = lv_btn_create(lv_scr_act(), NULL);
|
btnHoursPlus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnHoursPlus->user_data = this;
|
btnHoursPlus->user_data = this;
|
||||||
lv_obj_set_size(btnHoursPlus, 50, 40);
|
lv_obj_set_size(btnHoursPlus, 50, 40);
|
||||||
lv_obj_align(btnHoursPlus, lv_scr_act(), LV_ALIGN_CENTER, -72, -50);
|
lv_obj_align(btnHoursPlus, lv_scr_act(), LV_ALIGN_CENTER, -72, -50);
|
||||||
lv_obj_set_style_local_value_str(btnHoursPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
lv_obj_set_style_local_value_str(btnHoursPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
||||||
lv_obj_set_event_cb(btnHoursPlus, event_handler);
|
lv_obj_set_event_cb(btnHoursPlus, event_handler);
|
||||||
|
|
||||||
btnHoursMinus = lv_btn_create(lv_scr_act(), NULL);
|
btnHoursMinus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnHoursMinus->user_data = this;
|
btnHoursMinus->user_data = this;
|
||||||
lv_obj_set_size(btnHoursMinus, 50, 40);
|
lv_obj_set_size(btnHoursMinus, 50, 40);
|
||||||
lv_obj_align(btnHoursMinus, lv_scr_act(), LV_ALIGN_CENTER, -72, 40);
|
lv_obj_align(btnHoursMinus, lv_scr_act(), LV_ALIGN_CENTER, -72, 40);
|
||||||
lv_obj_set_style_local_value_str(btnHoursMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
lv_obj_set_style_local_value_str(btnHoursMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
||||||
lv_obj_set_event_cb(btnHoursMinus, event_handler);
|
lv_obj_set_event_cb(btnHoursMinus, event_handler);
|
||||||
|
|
||||||
btnMinutesPlus = lv_btn_create(lv_scr_act(), NULL);
|
btnMinutesPlus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnMinutesPlus->user_data = this;
|
btnMinutesPlus->user_data = this;
|
||||||
lv_obj_set_size(btnMinutesPlus, 50, 40);
|
lv_obj_set_size(btnMinutesPlus, 50, 40);
|
||||||
lv_obj_align(btnMinutesPlus, lv_scr_act(), LV_ALIGN_CENTER, 0, -50);
|
lv_obj_align(btnMinutesPlus, lv_scr_act(), LV_ALIGN_CENTER, 0, -50);
|
||||||
lv_obj_set_style_local_value_str(btnMinutesPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
lv_obj_set_style_local_value_str(btnMinutesPlus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "+");
|
||||||
lv_obj_set_event_cb(btnMinutesPlus, event_handler);
|
lv_obj_set_event_cb(btnMinutesPlus, event_handler);
|
||||||
|
|
||||||
btnMinutesMinus = lv_btn_create(lv_scr_act(), NULL);
|
btnMinutesMinus = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnMinutesMinus->user_data = this;
|
btnMinutesMinus->user_data = this;
|
||||||
lv_obj_set_size(btnMinutesMinus, 50, 40);
|
lv_obj_set_size(btnMinutesMinus, 50, 40);
|
||||||
lv_obj_align(btnMinutesMinus, lv_scr_act(), LV_ALIGN_CENTER, 0, 40);
|
lv_obj_align(btnMinutesMinus, lv_scr_act(), LV_ALIGN_CENTER, 0, 40);
|
||||||
lv_obj_set_style_local_value_str(btnMinutesMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
lv_obj_set_style_local_value_str(btnMinutesMinus, LV_BTN_PART_MAIN, LV_STATE_DEFAULT, "-");
|
||||||
lv_obj_set_event_cb(btnMinutesMinus, event_handler);
|
lv_obj_set_event_cb(btnMinutesMinus, event_handler);
|
||||||
|
|
||||||
btnSetTime = lv_btn_create(lv_scr_act(), NULL);
|
btnSetTime = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
btnSetTime->user_data = this;
|
btnSetTime->user_data = this;
|
||||||
lv_obj_set_size(btnSetTime, 120, 48);
|
lv_obj_set_size(btnSetTime, 120, 48);
|
||||||
lv_obj_align(btnSetTime, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
lv_obj_align(btnSetTime, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
||||||
|
@ -114,7 +112,6 @@ SettingSetTime::~SettingSetTime() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingSetTime::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
void SettingSetTime::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
||||||
|
|
||||||
if (event != LV_EVENT_CLICKED)
|
if (event != LV_EVENT_CLICKED)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -124,29 +121,25 @@ void SettingSetTime::HandleButtonPress(lv_obj_t *object, lv_event_t event) {
|
||||||
hoursValue = 0;
|
hoursValue = 0;
|
||||||
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnHoursMinus) {
|
||||||
else if (object == btnHoursMinus) {
|
|
||||||
hoursValue--;
|
hoursValue--;
|
||||||
if (hoursValue < 0)
|
if (hoursValue < 0)
|
||||||
hoursValue = 23;
|
hoursValue = 23;
|
||||||
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
lv_label_set_text_fmt(lblHours, "%02d", hoursValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnMinutesPlus) {
|
||||||
else if (object == btnMinutesPlus) {
|
|
||||||
minutesValue++;
|
minutesValue++;
|
||||||
if (minutesValue > 59)
|
if (minutesValue > 59)
|
||||||
minutesValue = 0;
|
minutesValue = 0;
|
||||||
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnMinutesMinus) {
|
||||||
else if (object == btnMinutesMinus) {
|
|
||||||
minutesValue--;
|
minutesValue--;
|
||||||
if (minutesValue < 0)
|
if (minutesValue < 0)
|
||||||
minutesValue = 59;
|
minutesValue = 59;
|
||||||
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
lv_label_set_text_fmt(lblMinutes, "%02d", minutesValue);
|
||||||
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
lv_btn_set_state(btnSetTime, LV_BTN_STATE_RELEASED);
|
||||||
}
|
} else if (object == btnSetTime) {
|
||||||
else if (object == btnSetTime) {
|
|
||||||
NRF_LOG_INFO("Setting time (manually) to %02d:%02d:00", hoursValue, minutesValue);
|
NRF_LOG_INFO("Setting time (manually) to %02d:%02d:00", hoursValue, minutesValue);
|
||||||
dateTimeController.SetTime(dateTimeController.Year(),
|
dateTimeController.SetTime(dateTimeController.Year(),
|
||||||
static_cast<uint8_t>(dateTimeController.Month()),
|
static_cast<uint8_t>(dateTimeController.Month()),
|
||||||
|
|
|
@ -6,10 +6,8 @@
|
||||||
#include "displayapp/screens/Screen.h"
|
#include "displayapp/screens/Screen.h"
|
||||||
|
|
||||||
namespace Pinetime {
|
namespace Pinetime {
|
||||||
|
|
||||||
namespace Applications {
|
namespace Applications {
|
||||||
namespace Screens {
|
namespace Screens {
|
||||||
|
|
||||||
class SettingSetTime : public Screen{
|
class SettingSetTime : public Screen{
|
||||||
public:
|
public:
|
||||||
SettingSetTime(DisplayApp* app, Pinetime::Controllers::DateTime &dateTimeController);
|
SettingSetTime(DisplayApp* app, Pinetime::Controllers::DateTime &dateTimeController);
|
||||||
|
@ -18,7 +16,6 @@ namespace Pinetime {
|
||||||
void HandleButtonPress(lv_obj_t *object, lv_event_t event);
|
void HandleButtonPress(lv_obj_t *object, lv_event_t event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
Controllers::DateTime& dateTimeController;
|
Controllers::DateTime& dateTimeController;
|
||||||
|
|
||||||
int hoursValue;
|
int hoursValue;
|
||||||
|
@ -30,7 +27,6 @@ namespace Pinetime {
|
||||||
lv_obj_t * btnMinutesPlus;
|
lv_obj_t * btnMinutesPlus;
|
||||||
lv_obj_t * btnMinutesMinus;
|
lv_obj_t * btnMinutesMinus;
|
||||||
lv_obj_t * btnSetTime;
|
lv_obj_t * btnSetTime;
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue