aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2025-03-17 22:04:02 +0100
committerdec05eba <dec05eba@protonmail.com>2025-03-17 22:44:49 +0100
commita6bd165d97b657cd51ab31aa6578513db0b47b42 (patch)
tree1319aefdc78045e8a7f2a81f7cc60b909f29b0e2
parentf9e1e3ec26685fef56af9a10c153821e8b7a0273 (diff)
Change joystick button to save replay. Add joystick buttons for more actions.
-rw-r--r--TODO4
-rw-r--r--include/GlobalHotkeysJoystick.hpp14
-rw-r--r--src/GlobalHotkeysJoystick.cpp55
-rw-r--r--src/Overlay.cpp15
-rw-r--r--src/gui/GlobalSettingsPage.cpp5
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 <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;
}