From 3d5e8baa5f66547f1250950b10bd4108e30af423 Mon Sep 17 00:00:00 2001 From: dec05eba Date: Sun, 25 Aug 2024 13:39:33 +0200 Subject: File chooser navigation --- depends/mglpp | 2 +- images/stream.png | Bin 5235 -> 7286 bytes images/up_arrow.png | Bin 0 -> 1426 bytes include/Theme.hpp | 1 + include/Utils.hpp | 4 + include/gui/Button.hpp | 1 + include/gui/FileChooser.hpp | 46 ++++++++-- include/gui/GsrPage.hpp | 13 ++- include/gui/ScrollablePage.hpp | 4 + include/gui/Utils.hpp | 2 + src/Theme.cpp | 3 + src/Utils.cpp | 18 ++++ src/gui/Button.cpp | 9 +- src/gui/FileChooser.cpp | 191 +++++++++++++++++++++++++++++++---------- src/gui/GsrPage.cpp | 40 ++++++--- src/gui/ScrollablePage.cpp | 90 +++++++++++++++++-- src/gui/SettingsPage.cpp | 26 ++++-- src/gui/Utils.cpp | 10 +++ src/main.cpp | 5 ++ 19 files changed, 380 insertions(+), 85 deletions(-) create mode 100644 images/up_arrow.png diff --git a/depends/mglpp b/depends/mglpp index 61b2725..685cd2d 160000 --- a/depends/mglpp +++ b/depends/mglpp @@ -1 +1 @@ -Subproject commit 61b2725ef174e4cec734e29bce4f69d6fcd2a813 +Subproject commit 685cd2d470b399a7aa82ae6a2942ffb0afefab9b diff --git a/images/stream.png b/images/stream.png index 970a673..198a06e 100644 Binary files a/images/stream.png and b/images/stream.png differ diff --git a/images/up_arrow.png b/images/up_arrow.png new file mode 100644 index 0000000..1be9fdc Binary files /dev/null and b/images/up_arrow.png differ diff --git a/include/Theme.hpp b/include/Theme.hpp index 7406c67..c70167b 100644 --- a/include/Theme.hpp +++ b/include/Theme.hpp @@ -31,6 +31,7 @@ namespace gsr { mgl::Texture combobox_arrow_texture; mgl::Texture settings_texture; mgl::Texture folder_texture; + mgl::Texture up_arrow_texture; double double_click_timeout_seconds = 0.4; }; diff --git a/include/Utils.hpp b/include/Utils.hpp index 6943e5e..b18ab8e 100644 --- a/include/Utils.hpp +++ b/include/Utils.hpp @@ -25,4 +25,8 @@ namespace gsr { std::string get_videos_dir(); int create_directory_recursive(char *path); bool file_get_content(const char *filepath, std::string &file_content); + + // Returns the path to the parent directory (ignoring trailing /) + // of "." if there is no parent directory and the directory path is relative + std::string get_parent_directory(std::string_view directory); } \ No newline at end of file diff --git a/include/gui/Button.hpp b/include/gui/Button.hpp index a4dcca1..bc1dd94 100644 --- a/include/gui/Button.hpp +++ b/include/gui/Button.hpp @@ -22,6 +22,7 @@ namespace gsr { void set_border_scale(float scale); const std::string& get_text() const; + void set_text(std::string str); std::function on_click; private: diff --git a/include/gui/FileChooser.hpp b/include/gui/FileChooser.hpp index 309ff56..36dac2d 100644 --- a/include/gui/FileChooser.hpp +++ b/include/gui/FileChooser.hpp @@ -1,16 +1,51 @@ #pragma once #include "Widget.hpp" +#include "ScrollablePage.hpp" #include #include #include +#include #include // This currently only supports displaying folders // TODO: Support files as well namespace gsr { + class FileChooser; + + class FileChooserBody : public Widget { + friend class FileChooser; + public: + FileChooserBody(FileChooser *file_chooser, mgl::vec2f size); + FileChooserBody(const FileChooserBody&) = delete; + FileChooserBody& operator=(const FileChooserBody&) = delete; + + bool on_event(mgl::Event &event, mgl::Window &window, mgl::vec2f offset) override; + void draw(mgl::Window &window, mgl::vec2f offset) override; + + mgl::vec2f get_size() override; + mgl::vec2f get_inner_size() override; + void set_size(mgl::vec2f size); + private: + void set_current_directory(const char *directory); + private: + struct Folder { + mgl::Text text; + time_t last_modified_seconds = 0; + }; + + FileChooser *file_chooser = nullptr; + mgl::vec2f size; + mgl::vec2f inner_size; + std::vector folders; + int mouse_over_item = -1; + int selected_item = -1; + mgl::Clock double_click_timer; + int times_clicked_within_timer = 0; + }; + class FileChooser : public Widget { public: FileChooser(const char *start_directory, mgl::vec2f size); @@ -23,6 +58,9 @@ namespace gsr { mgl::vec2f get_size() override; void set_current_directory(const char *directory); + void open_subdirectory(const char *name); + void open_parent_directory(); + const std::string& get_current_directory() const; private: struct Folder { mgl::Text text; @@ -31,10 +69,8 @@ namespace gsr { mgl::vec2f size; mgl::Text current_directory_text; - int mouse_over_item = -1; - int selected_item = -1; - std::vector folders; - mgl::Clock double_click_timer; - int times_clicked_within_timer = 0; + mgl::Sprite up_arrow_sprite; + ScrollablePage scrollable_page; + FileChooserBody *file_chooser_body_ptr = nullptr; }; } \ No newline at end of file diff --git a/include/gui/GsrPage.hpp b/include/gui/GsrPage.hpp index 916055a..1d298f4 100644 --- a/include/gui/GsrPage.hpp +++ b/include/gui/GsrPage.hpp @@ -3,6 +3,7 @@ #include "Page.hpp" #include "Button.hpp" +#include #include namespace gsr { @@ -19,9 +20,12 @@ namespace gsr { mgl::vec2f get_inner_size() override; void set_margins(float top, float bottom, float left, float right); - void set_on_back_button_click(std::function on_click_handler); + void add_button(const std::string &text, const std::string &id, mgl::Color color); + + std::function on_click; private: void draw_page_label(mgl::Window &window, mgl::vec2f body_pos); + void draw_buttons(mgl::Window &window, mgl::vec2f body_pos, mgl::vec2f body_size); void draw_children(mgl::Window &window, mgl::vec2f position); float get_border_size() const; @@ -29,11 +33,16 @@ namespace gsr { mgl::vec2f get_content_position(); mgl::vec2f get_content_position_with_margin(); private: + struct ButtonItem { + std::unique_ptr