diff options
author | dec05eba <dec05eba@protonmail.com> | 2025-03-17 22:04:02 +0100 |
---|---|---|
committer | dec05eba <dec05eba@protonmail.com> | 2025-03-17 22:44:49 +0100 |
commit | a6bd165d97b657cd51ab31aa6578513db0b47b42 (patch) | |
tree | 1319aefdc78045e8a7f2a81f7cc60b909f29b0e2 | |
parent | f9e1e3ec26685fef56af9a10c153821e8b7a0273 (diff) |
Change joystick button to save replay. Add joystick buttons for more actions.
-rw-r--r-- | TODO | 4 | ||||
-rw-r--r-- | include/GlobalHotkeysJoystick.hpp | 14 | ||||
-rw-r--r-- | src/GlobalHotkeysJoystick.cpp | 55 | ||||
-rw-r--r-- | src/Overlay.cpp | 15 | ||||
-rw-r--r-- | src/gui/GlobalSettingsPage.cpp | 5 |
5 files changed, 71 insertions, 22 deletions
@@ -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 <unordered_map> -#include <optional> #include <thread> #include <poll.h> -#include <mglpp/system/Clock.hpp> #include <linux/joystick.h> 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<double> 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 <sys/eventfd.h> 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<Label>(&get_theme().body_font, "Double-click the controller share button to save a replay", get_color_theme().text_color)); + list_ptr->add_widget(std::make_unique<Label>(&get_theme().body_font, "Press the PlayStation button and square to start/stop recording", get_color_theme().text_color)); + list_ptr->add_widget(std::make_unique<Label>(&get_theme().body_font, "Press the PlayStation button and X to start/stop replay", get_color_theme().text_color)); + list_ptr->add_widget(std::make_unique<Label>(&get_theme().body_font, "Press the PlayStation button and circle to save a replay", get_color_theme().text_color)); + list_ptr->add_widget(std::make_unique<Label>(&get_theme().body_font, "Press the PlayStation button and triangle to take a screenshot", get_color_theme().text_color)); list_ptr->add_widget(create_hotkey_control_buttons()); return subsection; } |