12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- /*******************
- * base_screen.cpp *
- *******************/
-
- /****************************************************************************
- * Written By Mark Pelletier 2017 - Aleph Objects, Inc. *
- * Written By Marcio Teixeira 2018 - Aleph Objects, Inc. *
- * *
- * This program is free software: you can redistribute it and/or modify *
- * it under the terms of the GNU General Public License as published by *
- * the Free Software Foundation, either version 3 of the License, or *
- * (at your option) any later version. *
- * *
- * This program is distributed in the hope that it will be useful, *
- * but WITHOUT ANY WARRANTY; without even the implied warranty of *
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
- * GNU General Public License for more details. *
- * *
- * To view a copy of the GNU General Public License, go to the following *
- * location: <https://www.gnu.org/licenses/>. *
- ****************************************************************************/
-
- #include "../config.h"
- #include "../screens.h"
-
- #ifdef FTDI_BASE_SCREEN
-
- using namespace FTDI;
- using namespace Theme;
-
- void BaseScreen::onEntry() {
- CommandProcessor cmd;
- cmd.set_button_style_callback(buttonStyleCallback);
- reset_menu_timeout();
- UIScreen::onEntry();
- }
-
- bool BaseScreen::buttonIsPressed(uint8_t tag) {
- return tag != 0 && EventLoop::get_pressed_tag() == tag;
- }
-
- bool BaseScreen::buttonStyleCallback(CommandProcessor &cmd, uint8_t tag, uint8_t &style, uint16_t &options, bool post) {
- if (post) {
- cmd.colors(normal_btn);
- return false;
- }
-
- #if HAS_SCREEN_TIMEOUT
- if (EventLoop::get_pressed_tag() != 0) {
- #if ENABLED(TOUCH_UI_DEBUG)
- SERIAL_ECHO_MSG("buttonStyleCallback, resetting timeout");
- #endif
- reset_menu_timeout();
- }
- #endif
-
- if (buttonIsPressed(tag)) options = OPT_FLAT;
-
- if (style & cmd.STYLE_DISABLED) {
- cmd.tag(0);
- style &= ~cmd.STYLE_DISABLED;
- cmd.colors(disabled_btn);
- return true; // Call me again to reset the colors
- }
- return false;
- }
-
- void BaseScreen::onIdle() {
- #if HAS_SCREEN_TIMEOUT
- if (EventLoop::get_pressed_tag() != 0)
- reset_menu_timeout();
-
- if ((millis() - last_interaction) > LCD_TIMEOUT_TO_STATUS) {
- reset_menu_timeout();
- #if ENABLED(TOUCH_UI_DEBUG)
- SERIAL_ECHO_MSG("Returning to status due to menu timeout");
- #endif
- GOTO_SCREEN(StatusScreen);
- }
- #endif
- }
-
- void BaseScreen::reset_menu_timeout() {
- TERN_(HAS_SCREEN_TIMEOUT, last_interaction = millis());
- }
-
- #if HAS_SCREEN_TIMEOUT
- uint32_t BaseScreen::last_interaction;
- #endif
-
- #endif // FTDI_BASE_SCREEN
|