Marlin_Firmware/Marlin/src/lcd/extui_example.cpp

116 lines
4.1 KiB
C++
Raw Normal View History

/*********************
* extui_example.cpp *
*********************/
2018-10-08 14:44:05 -06:00
/****************************************************************************
* 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 *
2020-07-23 05:20:14 +02:00
* location: <https://www.gnu.org/licenses/>. *
2018-10-08 14:44:05 -06:00
****************************************************************************/
#include "../inc/MarlinConfigPre.h"
2018-10-08 14:44:05 -06:00
#if BOTH(EXTUI_EXAMPLE, EXTENSIBLE_UI)
2018-10-08 14:44:05 -06:00
2020-03-13 16:29:29 -05:00
#include "extui/ui_api.h"
2018-10-08 14:44:05 -06:00
// To implement a new UI, complete the functions below and
// read or update Marlin's state using the methods in the
// ExtUI methods in "../ui_api.h"
//
// Although it may be possible to access other state
// variables from Marlin, using the API here possibly
// helps ensure future compatibility.
2018-10-08 14:44:05 -06:00
namespace ExtUI {
void onStartup() {
/* Initialize the display module here. The following
* routines are available for access to the GPIO pins:
*
* SET_OUTPUT(pin)
* SET_INPUT_PULLUP(pin)
* SET_INPUT(pin)
* WRITE(pin,value)
* READ(pin)
*/
}
void onIdle() {}
2019-10-09 18:46:10 -06:00
void onPrinterKilled(PGM_P const error, PGM_P const component) {}
void onMediaInserted() {};
void onMediaError() {};
void onMediaRemoved() {};
2018-10-08 14:44:05 -06:00
void onPlayTone(const uint16_t frequency, const uint16_t duration) {}
void onPrintTimerStarted() {}
void onPrintTimerPaused() {}
void onPrintTimerStopped() {}
void onFilamentRunout(const extruder_t extruder) {}
void onUserConfirmRequired(const char * const msg) {}
void onStatusChanged(const char * const msg) {}
2018-10-08 14:44:05 -06:00
void onFactoryReset() {}
void onStoreSettings(char *buff) {
2020-01-02 17:59:06 -06:00
// Called when saving to EEPROM (i.e. M500). If the ExtUI needs
// permanent data to be stored, it can write up to eeprom_data_size bytes
// into buff.
// Example:
// static_assert(sizeof(myDataStruct) <= ExtUI::eeprom_data_size);
// memcpy(buff, &myDataStruct, sizeof(myDataStruct));
}
void onLoadSettings(const char *buff) {
2020-01-02 17:59:06 -06:00
// Called while loading settings from EEPROM. If the ExtUI
// needs to retrieve data, it should copy up to eeprom_data_size bytes
// from buff
// Example:
// static_assert(sizeof(myDataStruct) <= ExtUI::eeprom_data_size);
// memcpy(&myDataStruct, buff, sizeof(myDataStruct));
}
void onConfigurationStoreWritten(bool success) {
2020-01-02 17:59:06 -06:00
// Called after the entire EEPROM has been written,
// whether successful or not.
}
void onConfigurationStoreRead(bool success) {
2020-01-02 17:59:06 -06:00
// Called after the entire EEPROM has been read,
// whether successful or not.
}
2019-10-07 16:39:52 -04:00
2020-05-02 23:13:14 +02:00
#if HAS_MESH
void onMeshUpdate(const int8_t xpos, const int8_t ypos, const float zval) {
// Called when any mesh points are updated
}
2020-01-04 11:00:44 +08:00
2020-05-02 23:13:14 +02:00
void onMeshUpdate(const int8_t xpos, const int8_t ypos, const ExtUI::probe_state_t state) {
// Called to indicate a special condition
}
#endif
2020-04-02 13:24:55 -06:00
2020-01-04 11:00:44 +08:00
#if ENABLED(POWER_LOSS_RECOVERY)
void onPowerLossResume() {
2020-01-04 11:00:44 +08:00
// Called on resume from power-loss
}
#endif
#if HAS_PID_HEATING
void onPidTuning(const result_t rst) {
2020-01-04 11:00:44 +08:00
// Called for temperature PID tuning result
}
#endif
2018-10-08 14:44:05 -06:00
}
#endif // EXTUI_EXAMPLE && EXTENSIBLE_UI