2023-07-31 14:28:10 -04:00
|
|
|
|
// OMOTE UI
|
|
|
|
|
// 2023 Matthew Colvin
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "Images.hpp"
|
2023-10-22 14:35:49 -04:00
|
|
|
|
#include "UIBase.hpp"
|
2023-08-11 18:16:48 -04:00
|
|
|
|
#include "lvgl.h"
|
2023-10-22 14:35:49 -04:00
|
|
|
|
#include "poller.hpp"
|
2023-07-31 14:28:10 -04:00
|
|
|
|
#include <algorithm>
|
|
|
|
|
#include <memory>
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <string>
|
2023-08-11 18:16:48 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
namespace UI::Basic {
|
2023-07-31 14:28:10 -04:00
|
|
|
|
/// @brief Singleton to allow UI code to live separately from the Initialization
|
|
|
|
|
/// of resources.
|
2023-10-22 14:35:49 -04:00
|
|
|
|
class OmoteUI : public UIBase {
|
2023-07-31 14:28:10 -04:00
|
|
|
|
public:
|
2023-09-14 00:34:04 -04:00
|
|
|
|
OmoteUI(std::shared_ptr<HardwareAbstract> aHardware);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
|
|
|
|
|
static std::weak_ptr<OmoteUI> getRefrence() { return getInstance(); };
|
2023-08-11 18:16:48 -04:00
|
|
|
|
static std::shared_ptr<OmoteUI>
|
2023-09-14 00:34:04 -04:00
|
|
|
|
getInstance(std::shared_ptr<HardwareAbstract> aHardware = nullptr) {
|
2023-07-31 14:28:10 -04:00
|
|
|
|
if (mInstance) {
|
|
|
|
|
return mInstance;
|
|
|
|
|
} else if (aHardware) {
|
|
|
|
|
mInstance = std::make_shared<OmoteUI>(aHardware);
|
|
|
|
|
}
|
|
|
|
|
return mInstance;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Set the page indicator scroll position relative to the tabview scroll
|
|
|
|
|
// position
|
|
|
|
|
void store_scroll_value_event_cb(lv_event_t *e);
|
|
|
|
|
// Update current device when the tabview page is changes
|
|
|
|
|
void tabview_device_event_cb(lv_event_t *e);
|
2023-09-17 06:14:39 -04:00
|
|
|
|
// Update wake timeout handler
|
|
|
|
|
void wakeTimeoutSetting_event_cb(lv_event_t *e);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
// Slider Event handler
|
|
|
|
|
void bl_slider_event_cb(lv_event_t *e);
|
|
|
|
|
// Apple Key Event handler
|
|
|
|
|
void appleKey_event_cb(lv_event_t *e);
|
|
|
|
|
// Wakeup by IMU Switch Event handler
|
|
|
|
|
void WakeEnableSetting_event_cb(lv_event_t *e);
|
|
|
|
|
// Smart Home Toggle Event handler
|
|
|
|
|
void smartHomeToggle_event_cb(lv_event_t *e);
|
|
|
|
|
// Smart Home Toggle Event handler
|
|
|
|
|
void smartHomeSlider_event_cb(lv_event_t *e);
|
|
|
|
|
// Virtual Keypad Event handler
|
|
|
|
|
void virtualKeypad_event_cb(lv_event_t *e);
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void wifi_settings_cb(lv_event_t *event);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void connect_btn_cb(lv_event_t *event);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void password_field_event_cb(lv_event_t *e);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
// Use LVGL to layout the ui and register the callbacks
|
|
|
|
|
void layout_UI();
|
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void ta_kb_event_cb(lv_event_t *e);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
void wifi_scan_done(std::shared_ptr<std::vector<WifiInfo>> info);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
void loopHandler();
|
2023-09-14 00:34:04 -04:00
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Function to hide the keyboard. If the keyboard is attached to a text
|
|
|
|
|
* area, it will be hidden when the text area is defocused. This function can
|
|
|
|
|
* be used if the keyboard need to be hidden due to some script event.
|
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
|
|
|
|
void hide_keyboard();
|
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Function to show the keyboard. If a text area needs the keybaord, it
|
|
|
|
|
* should be attached to the text area using the approbiate function. The
|
|
|
|
|
* keyboard will then show up when the text area is focused. This function is
|
2023-09-14 00:34:04 -04:00
|
|
|
|
* needed if the keyboard should be shown due to some script or other trigger.
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
|
|
|
|
void show_keyboard();
|
2023-07-31 14:28:10 -04:00
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
static std::shared_ptr<OmoteUI> mInstance;
|
2023-10-22 14:35:49 -04:00
|
|
|
|
|
2023-09-14 00:34:04 -04:00
|
|
|
|
std::unique_ptr<poller> batteryPoller;
|
2023-10-22 14:35:49 -04:00
|
|
|
|
|
2023-09-17 06:14:39 -04:00
|
|
|
|
int sleepTimeoutMap[5] = {10000,30000,60000,180000,600000};
|
|
|
|
|
|
2023-09-14 00:34:04 -04:00
|
|
|
|
void reset_settings_menu();
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void attach_keyboard(lv_obj_t *textarea);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
std::shared_ptr<std::vector<WifiInfo>> found_wifi_networks;
|
2023-10-22 14:35:49 -04:00
|
|
|
|
/**
|
|
|
|
|
* @brief Keyboard object used whenever a keyboard is needed.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
lv_obj_t *kb;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
/**
|
|
|
|
|
* @brief Function to create the keyboard object which can then be attached to
|
|
|
|
|
* different text areas.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
void create_keyboard();
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Set the up settings object
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
|
|
|
|
* @param parent
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void setup_settings(lv_obj_t *parent);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
/**
|
2023-09-14 00:34:04 -04:00
|
|
|
|
* @brief LVGL Menu for settings pages as needed.
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *settingsMenu;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Main page of the settings menu
|
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *settingsMainPage;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Battery percentage label
|
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *objBattPercentage;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Battery icon object in the status bar
|
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *objBattIcon;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
void create_status_bar();
|
2023-07-31 14:28:10 -04:00
|
|
|
|
|
|
|
|
|
lv_obj_t *panel = nullptr;
|
|
|
|
|
Images imgs = Images();
|
|
|
|
|
uint_fast8_t currentDevice = 4;
|
|
|
|
|
lv_color_t color_primary = lv_color_hex(0x303030); // gray
|
2023-08-11 18:16:48 -04:00
|
|
|
|
|
2023-07-31 14:28:10 -04:00
|
|
|
|
inline static const uint_fast8_t virtualKeyMapTechnisat[10] = {
|
|
|
|
|
0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0x0};
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
2023-10-22 14:35:49 -04:00
|
|
|
|
/************************************** WIFI Settings Menu
|
|
|
|
|
* *******************************************************/
|
2023-09-14 00:34:04 -04:00
|
|
|
|
/**
|
|
|
|
|
* @brief Container within the wifi selection page
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *wifi_setting_cont;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Wifi settings entry point on the settings tab
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *wifiOverview;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Label in the wifi password page. This label is updated with the
|
|
|
|
|
* selected SSID when the credentials for a wifi network is entered.
|
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *wifi_password_label;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Menu Subpage for the wifi password
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *wifi_password_page;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Menu Subpage for wifi selection
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *wifi_selection_page;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Wifi Label shown in the top status bar
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *WifiLabel;
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Number of wifi subpage needed to display the found wifi networks
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
|
|
|
|
unsigned int no_subpages;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief number of wifi networks found
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
|
|
|
|
unsigned int no_wifi_networks;
|
|
|
|
|
|
|
|
|
|
void wifi_status(std::shared_ptr<wifiStatus> status);
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief callback function to get next wifi subpage. This callback can be
|
|
|
|
|
* used to get the next or previous page
|
|
|
|
|
*
|
|
|
|
|
* @param e lvgl event object
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void next_wifi_selection_subpage(lv_event_t *e);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Create a wifi selection sub page object
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
|
|
|
|
* @param menu LVGL Menu where the sub page should be added to
|
2023-09-14 00:34:04 -04:00
|
|
|
|
* @return lv_obj_t* Menu sub page object pointer
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *create_wifi_selection_page(lv_obj_t *menu);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Method to create the wifi password sub page
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
|
|
|
|
* @param menu Menu where the sub page should be created
|
2023-09-14 00:34:04 -04:00
|
|
|
|
* @return lv_obj_t* menu sub page object pointer
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
lv_obj_t *create_wifi_password_page(lv_obj_t *menu);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Method to create the wifi settings on the main page
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
|
|
|
|
* @param parent lv object parent where the main settings page should be
|
|
|
|
|
* added to
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void create_wifi_main_page(lv_obj_t *parent);
|
2023-09-14 00:34:04 -04:00
|
|
|
|
|
|
|
|
|
/**
|
2023-10-22 14:35:49 -04:00
|
|
|
|
* @brief Method to create wifi settings. This method will call the
|
|
|
|
|
* create_wifi_selection_page, the create_wifi_password_page, and the
|
|
|
|
|
* create_wifi_main_page
|
|
|
|
|
*
|
|
|
|
|
* @param menu Settings menu where the sub pages should be added to
|
|
|
|
|
* @param parent lv object parent where the main settings page should be
|
|
|
|
|
* added to
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void create_wifi_settings(lv_obj_t *menu, lv_obj_t *parent);
|
|
|
|
|
|
2023-09-14 00:34:04 -04:00
|
|
|
|
/**
|
|
|
|
|
* @brief Function to update the wifi selection sub page
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
|
|
|
|
* @param page index of the page to display
|
2023-09-14 00:34:04 -04:00
|
|
|
|
*/
|
|
|
|
|
void update_wifi_selection_subpage(int page);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Function to create the display settings page.
|
2023-10-22 14:35:49 -04:00
|
|
|
|
*
|
2023-09-14 00:34:04 -04:00
|
|
|
|
* @param parent LVGL object acting as a parent for the display settings page
|
|
|
|
|
*/
|
2023-10-22 14:35:49 -04:00
|
|
|
|
void display_settings(lv_obj_t *parent);
|
2023-07-31 14:28:10 -04:00
|
|
|
|
};
|
2023-10-22 14:35:49 -04:00
|
|
|
|
|
|
|
|
|
} // namespace UI::Basic
|