From a6bd165d97b657cd51ab31aa6578513db0b47b42 Mon Sep 17 00:00:00 2001 From: dec05eba Date: Mon, 17 Mar 2025 22:04:02 +0100 Subject: Change joystick button to save replay. Add joystick buttons for more actions. --- TODO | 4 +++ include/GlobalHotkeysJoystick.hpp | 14 +++++++--- src/GlobalHotkeysJoystick.cpp | 55 +++++++++++++++++++++++++++------------ src/Overlay.cpp | 15 +++++++++++ src/gui/GlobalSettingsPage.cpp | 5 +++- 5 files changed, 71 insertions(+), 22 deletions(-) diff --git a/TODO b/TODO index 551b095..8eced48 100644 --- a/TODO +++ b/TODO @@ -142,3 +142,7 @@ Allow using a hotkey such as printscreen or any other non-alphanumeric key witho Use x11 shm instead of XGetImage (https://stackoverflow.com/questions/43442675/how-to-use-xshmgetimage-and-xshmputimage). Add a hotkey to record/stream/replay/screenshot region. + +Do xi grab for keys as well. Otherwise the ui cant be used for keyboard input if a program has grabbed the keyboard, and there could possibly be a game that grabs the keyboard as well. + +Make inactive buttons gray (in dropdown boxes and in the front page with save, etc when replay is not running). \ No newline at end of file diff --git a/include/GlobalHotkeysJoystick.hpp b/include/GlobalHotkeysJoystick.hpp index 69f66df..7dbb272 100644 --- a/include/GlobalHotkeysJoystick.hpp +++ b/include/GlobalHotkeysJoystick.hpp @@ -3,10 +3,8 @@ #include "GlobalHotkeys.hpp" #include "Hotplug.hpp" #include -#include #include #include -#include #include namespace gsr { @@ -21,6 +19,11 @@ namespace gsr { ~GlobalHotkeysJoystick() override; bool start(); + // Currently valid ids: + // save_replay + // take_screenshot + // toggle_record + // toggle_replay bool bind_action(const std::string &id, GlobalHotkeyCallback callback) override; void poll_events() override; private: @@ -45,9 +48,12 @@ namespace gsr { int event_fd = -1; int event_index = -1; - mgl::Clock double_click_clock; - std::optional prev_time_clicked; + bool playstation_button_pressed = false; + bool save_replay = false; + bool take_screenshot = false; + bool toggle_record = false; + bool toggle_replay = false; int hotplug_poll_index = -1; Hotplug hotplug; }; diff --git a/src/GlobalHotkeysJoystick.cpp b/src/GlobalHotkeysJoystick.cpp index dfe1e6f..2a33738 100644 --- a/src/GlobalHotkeysJoystick.cpp +++ b/src/GlobalHotkeysJoystick.cpp @@ -6,7 +6,12 @@ #include namespace gsr { - static constexpr double double_click_timeout_seconds = 0.33; + static constexpr int button_pressed = 1; + static constexpr int playstation_button = 10; + static constexpr int x_button = 0; + static constexpr int circle_button = 1; + static constexpr int triangle_button = 2; + static constexpr int square_button = 3; // Returns -1 on error static int get_js_dev_input_id_from_filepath(const char *dev_input_filepath) { @@ -99,6 +104,27 @@ namespace gsr { if(it != bound_actions_by_id.end()) it->second("save_replay"); } + + if(take_screenshot) { + take_screenshot = false; + auto it = bound_actions_by_id.find("take_screenshot"); + if(it != bound_actions_by_id.end()) + it->second("take_screenshot"); + } + + if(toggle_record) { + toggle_record = false; + auto it = bound_actions_by_id.find("toggle_record"); + if(it != bound_actions_by_id.end()) + it->second("toggle_record"); + } + + if(toggle_replay) { + toggle_replay = false; + auto it = bound_actions_by_id.find("toggle_replay"); + if(it != bound_actions_by_id.end()) + it->second("toggle_replay"); + } } void GlobalHotkeysJoystick::read_events() { @@ -156,22 +182,17 @@ namespace gsr { if((event.type & JS_EVENT_BUTTON) == 0) return; - if(event.number == 8 && event.value == 1) { - const double now = double_click_clock.get_elapsed_time_seconds(); - if(!prev_time_clicked.has_value()) { - prev_time_clicked = now; - return; - } - - if(prev_time_clicked.has_value()) { - const bool double_clicked = (now - prev_time_clicked.value()) < double_click_timeout_seconds; - if(double_clicked) { - save_replay = true; - prev_time_clicked.reset(); - } else { - prev_time_clicked = now; - } - } + if(event.number == playstation_button) { + playstation_button_pressed = event.value == button_pressed; + } else if(playstation_button_pressed && event.value == button_pressed) { + if(event.number == circle_button) + save_replay = true; + else if(event.number == triangle_button) + take_screenshot = true; + else if(event.number == square_button) + toggle_record = true; + else if(event.number == x_button) + toggle_replay = true; } } diff --git a/src/Overlay.cpp b/src/Overlay.cpp index 1147cc7..63f9822 100644 --- a/src/Overlay.cpp +++ b/src/Overlay.cpp @@ -339,6 +339,21 @@ namespace gsr { overlay->save_replay(); }); + global_hotkeys_js->bind_action("take_screenshot", [overlay](const std::string &id) { + fprintf(stderr, "pressed %s\n", id.c_str()); + overlay->take_screenshot(); + }); + + global_hotkeys_js->bind_action("toggle_record", [overlay](const std::string &id) { + fprintf(stderr, "pressed %s\n", id.c_str()); + overlay->toggle_record(); + }); + + global_hotkeys_js->bind_action("toggle_replay", [overlay](const std::string &id) { + fprintf(stderr, "pressed %s\n", id.c_str()); + overlay->toggle_replay(); + }); + return global_hotkeys_js; } diff --git a/src/gui/GlobalSettingsPage.cpp b/src/gui/GlobalSettingsPage.cpp index 0abb4f9..82baa86 100644 --- a/src/gui/GlobalSettingsPage.cpp +++ b/src/gui/GlobalSettingsPage.cpp @@ -340,7 +340,10 @@ namespace gsr { list_ptr->add_widget(create_record_hotkey_options()); list_ptr->add_widget(create_stream_hotkey_options()); list_ptr->add_widget(create_screenshot_hotkey_options()); - list_ptr->add_widget(std::make_unique