[gnome-games/wip/exalm/dpad: 43/44] gamepad-mapping-builder: Support binding half axes
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-games/wip/exalm/dpad: 43/44] gamepad-mapping-builder: Support binding half axes
- Date: Sat, 9 Feb 2019 13:58:11 +0000 (UTC)
commit 729aa3efd5022a9c1fcec107a0c50aca2734bff5
Author: Alexander Mikhaylenko <exalm7659 gmail com>
Date: Fri Oct 12 02:06:10 2018 +0500
gamepad-mapping-builder: Support binding half axes
Add a 'range' parameter to set_axis_mapping() that allows to only bind
positive or negative half.
src/gamepad/gamepad-mapping-builder.vala | 37 ++++++++++++++++++++++++++++++--
src/ui/gamepad-mapper.vala | 2 +-
2 files changed, 36 insertions(+), 3 deletions(-)
---
diff --git a/src/gamepad/gamepad-mapping-builder.vala b/src/gamepad/gamepad-mapping-builder.vala
index ddd25724..6533119a 100644
--- a/src/gamepad/gamepad-mapping-builder.vala
+++ b/src/gamepad/gamepad-mapping-builder.vala
@@ -35,12 +35,19 @@ private class Games.GamepadMappingBuilder : Object {
string destination_string;
}
+ private struct GamepadAxisMapping {
+ bool positive_mapped;
+ bool negative_mapped;
+ }
+
private GamepadInputMapping[] mappings;
private GamepadDPad[] dpads;
+ private HashTable<string, GamepadAxisMapping?> axes;
construct {
mappings = new GamepadInputMapping[]{};
dpads = new GamepadDPad[]{};
+ axes = new HashTable<string, GamepadAxisMapping?> (str_hash, str_equal);
}
public string build_sdl_string () {
@@ -56,8 +63,34 @@ private class Games.GamepadMappingBuilder : Object {
return add_destination (@"b$(hardware_index)", source);
}
- public bool set_axis_mapping (uint8 hardware_index, GamepadInput source) {
- return add_destination (@"a$(hardware_index)", source);
+ // FIXME: range should have Manette.MappingRange type
+ public bool set_axis_mapping (uint8 hardware_index, int range, GamepadInput source) {
+ var destination = @"a$(hardware_index)";
+
+ var positive = range >= 0;
+ var negative = range <= 0;
+
+ if (!(destination in axes))
+ axes[destination] = { false, false };
+
+ var mapping = axes[destination];
+
+ if ((positive && mapping.positive_mapped) ||
+ (negative && mapping.negative_mapped))
+ return false;
+
+ axes[destination] = {
+ mapping.positive_mapped || positive,
+ mapping.negative_mapped || negative
+ };
+
+ if (range > 0)
+ return add_destination (@"+$(destination)", source);
+
+ if (range < 0)
+ return add_destination (@"-$(destination)", source);
+
+ return add_destination (destination, source);
}
public bool set_hat_mapping (uint8 hardware_index, int32 value, GamepadInput source) {
diff --git a/src/ui/gamepad-mapper.vala b/src/ui/gamepad-mapper.vala
index 93eb3bdc..2af64125 100644
--- a/src/ui/gamepad-mapper.vala
+++ b/src/ui/gamepad-mapper.vala
@@ -77,7 +77,7 @@ private class Games.GamepadMapper : Gtk.Bin {
return;
if (!mapping_builder.set_axis_mapping ((uint8) event.get_hardware_index (),
- input))
+ 0, input))
return;
break;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]