gui::PagesControl renamed to gui::Menu

This commit is contained in:
MihailRis 2024-03-22 09:46:29 +03:00
parent b3f3ef8123
commit 71f4dff32f
7 changed files with 49 additions and 28 deletions

View File

@ -21,7 +21,7 @@ GUI::GUI() {
uicamera->perspective = false;
uicamera->flipped = true;
menu = std::make_shared<PagesControl>();
menu = std::make_shared<Menu>();
menu->setId("menu");
container->add(menu);
container->setScrollable(false);
@ -30,7 +30,7 @@ GUI::GUI() {
GUI::~GUI() {
}
std::shared_ptr<PagesControl> GUI::getMenu() {
std::shared_ptr<Menu> GUI::getMenu() {
return menu;
}

View File

@ -49,7 +49,7 @@ class Camera;
namespace gui {
class UINode;
class Container;
class PagesControl;
class Menu;
/// @brief The main UI controller
class GUI {
@ -60,15 +60,15 @@ namespace gui {
std::unordered_map<std::string, std::shared_ptr<UINode>> storage;
std::unique_ptr<Camera> uicamera;
std::shared_ptr<PagesControl> menu;
std::shared_ptr<Menu> menu;
std::queue<runnable> postRunnables;
void actMouse(float delta);
public:
GUI();
~GUI();
/// @brief Get the main menu (PagesControl) node
std::shared_ptr<PagesControl> getMenu();
/// @brief Get the main menu (Menu) node
std::shared_ptr<Menu> getMenu();
/// @brief Get current focused node
/// @return focused node or nullptr

View File

@ -246,22 +246,23 @@ Orientation Panel::getOrientation() const {
return orientation;
}
PagesControl::PagesControl() : Container(glm::vec2(1)){
Menu::Menu() : Container(glm::vec2(1)){
}
bool PagesControl::has(const std::string& name) {
return pages.find(name) != pages.end();
bool Menu::has(const std::string& name) {
return pages.find(name) != pages.end() ||
pageSuppliers.find(name) != pageSuppliers.end();
}
void PagesControl::addPage(std::string name, std::shared_ptr<UINode> panel) {
void Menu::addPage(std::string name, std::shared_ptr<UINode> panel) {
pages[name] = Page{panel};
}
void PagesControl::addSupplier(std::string name, supplier<std::shared_ptr<UINode>> pageSupplier) {
void Menu::addSupplier(std::string name, supplier<std::shared_ptr<UINode>> pageSupplier) {
pageSuppliers[name] = pageSupplier;
}
void PagesControl::setPage(std::string name, bool history) {
void Menu::setPage(std::string name, bool history) {
auto found = pages.find(name);
Page page;
if (found == pages.end()) {
@ -270,6 +271,7 @@ void PagesControl::setPage(std::string name, bool history) {
throw std::runtime_error("no page found");
} else {
page.panel = supplier->second();
// supplied pages caching is not implemented
}
} else {
page = found->second;
@ -286,7 +288,7 @@ void PagesControl::setPage(std::string name, bool history) {
setSize(current.panel->getSize());
}
void PagesControl::back() {
void Menu::back() {
if (pageStack.empty())
return;
std::string name = pageStack.top();
@ -294,19 +296,19 @@ void PagesControl::back() {
setPage(name, false);
}
Page& PagesControl::getCurrent() {
Page& Menu::getCurrent() {
return current;
}
const std::string& PagesControl::getCurrentName() const {
const std::string& Menu::getCurrentName() const {
return curname;
}
void PagesControl::clearHistory() {
void Menu::clearHistory() {
pageStack = std::stack<std::string>();
}
void PagesControl::reset() {
void Menu::reset() {
clearHistory();
if (current.panel) {
curname = "";

View File

@ -92,7 +92,7 @@ namespace gui {
}
};
class PagesControl : public Container {
class Menu : public Container {
protected:
std::unordered_map<std::string, Page> pages;
std::stack<std::string> pageStack;
@ -100,17 +100,36 @@ namespace gui {
std::string curname = "";
std::unordered_map<std::string, supplier<std::shared_ptr<UINode>>> pageSuppliers;
public:
PagesControl();
Menu();
/// @brief Check menu have page or page supplier
/// @param name page name
bool has(const std::string& name);
/// @brief Set current page to specified one.
/// @param name page or page supplier name
/// @param history previous page will not be saved in history if false
void setPage(std::string name, bool history=true);
void addPage(std::string name, std::shared_ptr<UINode> panel);
/// @brief Add page supplier used if page is not found
/// @param name page name
/// @param pageSupplier page supplier function
void addSupplier(std::string name, supplier<std::shared_ptr<UINode>> pageSupplier);
/// @brief Set page to previous saved in history
void back();
/// @brief Clear pages history
void clearHistory();
/// @brief Clear history and remove and set page to null
void reset();
/// @brief Get current page
Page& getCurrent();
/// @brief Get current page name
const std::string& getCurrentName() const;
};
}

View File

@ -12,7 +12,7 @@
using namespace gui;
std::shared_ptr<Button> guiutil::backButton(std::shared_ptr<PagesControl> menu) {
std::shared_ptr<Button> guiutil::backButton(std::shared_ptr<Menu> menu) {
return std::dynamic_pointer_cast<Button>(create(
"<button padding='10' onclick='menu:back()'>@Back</button>"
));
@ -21,7 +21,7 @@ std::shared_ptr<Button> guiutil::backButton(std::shared_ptr<PagesControl> menu)
std::shared_ptr<Button> guiutil::gotoButton(
std::wstring text,
const std::string& page,
std::shared_ptr<PagesControl> menu
std::shared_ptr<Menu> menu
) {
text = langs::get(text, L"menu");
return std::dynamic_pointer_cast<Button>(create(

View File

@ -12,13 +12,13 @@ namespace gui {
namespace guiutil {
std::shared_ptr<gui::Button> backButton(
std::shared_ptr<gui::PagesControl> menu
std::shared_ptr<gui::Menu> menu
);
std::shared_ptr<gui::Button> gotoButton(
std::wstring text,
const std::string& page,
std::shared_ptr<gui::PagesControl> menu
std::shared_ptr<gui::Menu> menu
);
/// @brief Create element from XML

View File

@ -130,12 +130,12 @@ static gui::UINode* getDocumentNode(lua_State* L) {
static int menu_back(lua_State* L) {
auto node = getDocumentNode(L);
auto menu = dynamic_cast<gui::PagesControl*>(node);
auto menu = dynamic_cast<gui::Menu*>(node);
menu->back();
return 0;
}
static bool getattr(lua_State* L, gui::PagesControl* menu, const std::string& attr) {
static bool getattr(lua_State* L, gui::Menu* menu, const std::string& attr) {
if (menu == nullptr)
return false;
if (attr == "page") {
@ -193,7 +193,7 @@ static bool setattr(lua_State* L, gui::Label* label, const std::string& attr) {
return false;
}
static bool setattr(lua_State* L, gui::PagesControl* menu, const std::string& attr) {
static bool setattr(lua_State* L, gui::Menu* menu, const std::string& attr) {
if (menu == nullptr)
return false;
if (attr == "page") {
@ -260,7 +260,7 @@ static int l_gui_getattr(lua_State* L) {
return 1;
if (getattr(L, dynamic_cast<gui::FullCheckBox*>(node), attr))
return 1;
if (getattr(L, dynamic_cast<gui::PagesControl*>(node), attr))
if (getattr(L, dynamic_cast<gui::Menu*>(node), attr))
return 1;
return 0;
@ -300,7 +300,7 @@ static int l_gui_setattr(lua_State* L) {
return 0;
if (setattr(L, dynamic_cast<gui::FullCheckBox*>(node), attr))
return 0;
if (setattr(L, dynamic_cast<gui::PagesControl*>(node), attr))
if (setattr(L, dynamic_cast<gui::Menu*>(node), attr))
return 0;
}
return 0;