FEATURE: New numeric menu type

This commit is contained in:
Robin Dietzel 2023-01-04 14:54:51 +01:00
parent 029f2745d1
commit c1f7cbc865
8 changed files with 102 additions and 12 deletions

View File

@ -7,6 +7,6 @@
// Auto generated header file containing the last git revision // Auto generated header file containing the last git revision
#define GIT_HASH "29dd3f3" #define GIT_HASH "27146c9"
#endif //FLOATPUMP_GIT_REVISION_TEMPLATE_H #endif //FLOATPUMP_GIT_REVISION_TEMPLATE_H

View File

@ -8,6 +8,7 @@
#include "button_input.h" #include "button_input.h"
#include "Menu.h" #include "Menu.h"
#include "Menu_Entry_Type_Checkable.h" #include "Menu_Entry_Type_Checkable.h"
#include "Menu_Entry_Type_Numeric.h"
#define SLAVE_ADDRESS_LCD 0x4e #define SLAVE_ADDRESS_LCD 0x4e
@ -94,6 +95,9 @@ int main(void) {
mainmenu.addEntry(entry3); mainmenu.addEntry(entry3);
mainmenu.addEntry(entry3); mainmenu.addEntry(entry3);
Menu_Entry integer(new Menu_Entry_Type_Numeric, "Val");
mainmenu.addEntry(integer);
static int old_pos = 0; static int old_pos = 0;
while (1) { while (1) {

View File

@ -38,11 +38,15 @@ namespace floatpump {
m_driver.LCDSetCursor(1,i); m_driver.LCDSetCursor(1,i);
int entry_index = (page * 4) + i; int entry_index = (page * 4) + i;
if( m_entries.size() > entry_index) { if( m_entries.size() > entry_index ) {
std::string dspstring = m_entries[entry_index].printLine(); std::string dspstring = m_entries[entry_index].printLine();
if(dspstring.length() > 19) {
m_driver.LCDSendCString("-------------------");
} else {
dspstring.append((19 - dspstring.length()), ' '); dspstring.append((19 - dspstring.length()), ' ');
m_driver.LCDSendCString(const_cast<char *>(dspstring.c_str())); m_driver.LCDSendCString(const_cast<char *>(dspstring.c_str()));
}
} else { } else {
m_driver.LCDSendCString("-------------------"); m_driver.LCDSendCString("-------------------");
} }
@ -57,14 +61,21 @@ namespace floatpump {
} }
void increase() { void increase() {
if(m_first_index < m_entries.size() - 1) if(m_entries[m_first_index].isEntered()) {
m_entries[m_first_index].action_increase();
} else if(m_first_index < m_entries.size() - 1 && !m_entries[m_first_index].isEntered()) {
m_first_index++; m_first_index++;
} }
}
void decrease() { void decrease() {
if(m_first_index > 0) if(m_entries[m_first_index].isEntered()) {
m_entries[m_first_index].action_decrease();
} else if(m_first_index > 0) {
m_first_index--; m_first_index--;
} }
}
private: private:
LCD_I2C_Driver &m_driver; LCD_I2C_Driver &m_driver;
std::vector<Menu_Entry> m_entries; std::vector<Menu_Entry> m_entries;

View File

@ -18,7 +18,10 @@ namespace floatpump {
Menu_Entry(Menu_Entry_Type_Delegate *type, std::string name) : m_type(type), m_name(name) {}; Menu_Entry(Menu_Entry_Type_Delegate *type, std::string name) : m_type(type), m_name(name) {};
std::string printLine() { std::string printLine() {
return m_name + ": " + m_type->toString(); int spaces = 19 - (m_name.length() + m_type->toString().length());
std::string spacer;
spacer.append(spaces, ' ');
return m_name + spacer + m_type->toString();
} }
void action_press() { void action_press() {
@ -33,6 +36,10 @@ namespace floatpump {
m_type->u_decrease(1); m_type->u_decrease(1);
} }
bool isEntered() {
return m_type->isEntered();
}
private: private:
std::string m_name; std::string m_name;
}; };

View File

@ -13,7 +13,7 @@ namespace floatpump {
class Menu_Entry_Type_Checkable : public Menu_Entry_Type_Delegate { class Menu_Entry_Type_Checkable : public Menu_Entry_Type_Delegate {
public: public:
std::string toString() override { std::string toString() override {
return std::string((m_state) ? "True" : "false"); return std::string((m_state) ? "ON " : "OFF");
} }
void u_press() override { void u_press() override {
@ -28,7 +28,9 @@ namespace floatpump {
} }
bool enterable = false; bool isEntered() override {
return false;
}
private: private:
bool m_state = false; bool m_state = false;

View File

@ -17,8 +17,7 @@ namespace floatpump {
virtual void u_press() = 0; virtual void u_press() = 0;
virtual void u_increase(uint16_t steps = 1) = 0; virtual void u_increase(uint16_t steps = 1) = 0;
virtual void u_decrease(uint16_t steps = 1) = 0; virtual void u_decrease(uint16_t steps = 1) = 0;
virtual bool isEntered() = 0;
bool enterable = true;
}; };
} // floatpump } // floatpump

View File

@ -0,0 +1,34 @@
//
// Created by robtor on 04.01.23.
//
#ifndef FLOATPUMP_MENU_ENTRY_TYPE_NUMERIC_H
#define FLOATPUMP_MENU_ENTRY_TYPE_NUMERIC_H
#include <string>
#include "Menu_Entry_Type_Delegate.h"
namespace floatpump {
namespace menu {
class Menu_Entry_Type_Numeric : public Menu_Entry_Type_Delegate {
public:
std::string toString() override;
void u_press() override;
void u_increase(uint16_t steps) override;
void u_decrease(uint16_t steps) override;
bool isEntered() override;
private:
uint16_t m_value = 0;
bool m_entered = false;
};
} // floatpump
} // menu
#endif //FLOATPUMP_MENU_ENTRY_TYPE_NUMERIC_H

View File

@ -0,0 +1,33 @@
//
// Created by robtor on 04.01.23.
//
#include "Menu_Entry_Type_Numeric.h"
namespace floatpump {
namespace menu {
std::string Menu_Entry_Type_Numeric::toString() {
if(m_entered) {
return "#" + std::to_string(m_value);
} else {
return " " + std::to_string(m_value);
}
}
void Menu_Entry_Type_Numeric::u_press() {
m_entered = !m_entered;
}
void Menu_Entry_Type_Numeric::u_increase(uint16_t steps) {
m_value++;
}
void Menu_Entry_Type_Numeric::u_decrease(uint16_t steps) {
m_value--;
}
bool Menu_Entry_Type_Numeric::isEntered() {
return m_entered;
}
} // floatpump
} // menu