-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Right stick up-down input not working properly with Xbox Elite Wireless Controller Series 2 #81816
Comments
Which controller model are you using (and with which connection mode)? Try another controller and see if its mappings are correct. |
Have you tried the controller in a different program and confirmed it works there? |
@AThousandShips Yes, I've played few games to test it before + you can check video, another program detects it correctly.
@Calinou Xbox Elite Wireless Controller Series 2. I use it wireless. Unfourtanetly I don't have another controller to test, but it works well in another programs and games. |
Couldn't watch the video when I asked, and not everyone can access a video, so important to add it to the details for those who can't |
@Calinou @AThousandShips I've tested controller by wire right now and it works as expected, so problem with wireless connection only. Added this info to issue details. |
How can I help to fix it? |
@s-titov can you post a minimal project that replicates the issue? The values you're getting are very strange. I don't see anything in particular in the Godot engine code for handling joysticks that could cause this. It looks like the RS Y-axis is not being reported correctly by Windows, or maybe there is software modifying the input because Godot sees it. I don't have an Elite controller, and I'm not able to replicate any bug like with the controllers I do have (Xbox and others). If you have any customized mapping through Xbox for Windows or any other modding software, can you disable or reset those settings? If you don't have anything like that, then please create a new project and copy the bits of your code you have (and input mapping), verify the problem still exists, and upload that project here. You should be able to recreate the bug with a basic node, the input mappings, and the code you have that prints the values to the console output. |
I've also run into this issue using an Xbox Elite Controller in my project, but only wireless as mentioned. When plugged in, it behaves normally, but wireless, the vertical axis value seems to jump around wildly. Moving the same input maps for the joystick and code that I use to get the values into a fresh project also causes the same issue. 2023-09-23.09-53-39.online-video-cutter.com.mp4I've tried moving it from _Process to _PhysicsProcess and updating the controller to no avail. One additional weird thing I caught was that sometimes when I selected the node that had the script retrieving the value, it would begin to read those values properly. It wouldn't do it every time, but I caught a video of it in my personal project and it did happen in this fresh project. 2023-09-23.09-39-12.mp4Here's a ZIP file for the new project that should show everything from the first video. Of note, I don't use any external software to modify my controller or any input mappings. |
Done
I don't have
Yes, problem still exists |
Upon further testing, it actually appears that the issue only happens when the game window is selected, not when the node is selected as I thought. If you focus on any other window, even not the Godot editor, the game receives the joystick input properly. This goes for both my project and the fresh project I uploaded. 2023-09-23.12-37-18.mp4 |
I have the same behavior: if I change focus to another window it works as expected |
I'm wondering if there is something different going on between XInput and DirectInput in Windows. SDL has two separate GUIDs for the Series 2 Elite controller, but Godot has just one. Also the Godot I have not tested this in XInput yet, but I found reports that it only works when the window is in focus, so maybe your controller, as wireless, is being processed as a Raw Device and not recognized by GUID, and then when switching focus it instead is going through the DirectInput library to process input. Can you (@s-titov or @KarpDevStudio) compare the GUIDs you're getting through Device Manager to those listed in Godot and SDL? I'm not sure exactly how to compare (should be able to from fields in Device Mananger, just not sure which exactly), and I'm not home at the moment, but I will check with my own controllers when I am. If you can confirm the Elite Series 2 you're using is not listed in Godot, then that might lead to something here. Also, are you able to compile Godot from source? You'll need to in order to test a fix (adding the GUID if it's missing), or otherwise someone will have to provide you a binary to test with. |
Well this is getting more interesting...I'm seeing two devices showing up in device manager for each controller, though that makes sense if one registers through XInput (as their name implies) and the other with DirectInput. You can verify the I have three different models, and when connected with USB, all had
Those are all listed in Godot. If they're not all going through XInput, I don't know if they should be listed for XInput, but then those also wouldn't be used, assuming those values wouldn't show through XInput. When either of you get a chance, please verify the HID and PID values for your Elite Series 2. When wired, you'll probably see it listed under |
I'm also experiencing this with an Xbox controller using PopOS with 4.2 dev 5.
The controllers work correctly in games over Steam and such. It seems as though the input axis are being registered opposite where left and right on the right stick will output up and down and vice versa and also there is another axis being used for some reason for up and down. I only have one controller attached and the correct and expected joystick inputs are already set in the screenshots: When I move the right stick.... To the right: To the left: Right stick up: Right stick down: |
@floatingpointer Here are the values for my controller when wired:
When wireless, the controller shows up as HID-compliant game controller under Human Interface Devices, instead of Bluetooth XInput compatible Input device as mentioned. This has a VID of 045e and a PID of 0b22. I can also confirm that the above information from @Mikeysax also happens on my device using Windows 11 when using the joystick to assign input instead of manually assigning it. |
Okay, got it. Here is my fork with the added XInput device, so you can build it from source if you'd like. If not, here is one I built using the current 4.1.2 source, and here is the updated version with the added device ID. I'm including both in case there's some oddity in what I used to build it (Visual Studio 2022 on Windows 11) and whatever the official release was built with, so if the update works, please verify that the one built from the original source does not work (as expected). |
That did the trick, using your two builds confirmed the base 4.1.2 source has the issue, while adding the device ID fixes it. This also fixes the issue with assigning the input via joystick input as mentioned by @Mikeysax, they now show up properly as "Right Stick Up", "Right Stick Down", etc. 2023-09-28.18-50-34.mp4 |
Thanks for verifying! Opened PR #82508 |
Godot version
v4.1.1.stable.official [bd6af8e]
System information
Godot v4.1.1.stable - Windows 10.0.22621 - Vulkan (Forward+) - dedicated NVIDIA GeForce RTX 4090 (NVIDIA; 31.0.15.3713) - 13th Gen Intel(R) Core(TM) i7-13700K (24 Threads)
Issue description
When I move right stick to right-top corner I expect to see
Right Stick Up
, but actual isRight Stick Down
.I've tested controller in another games and programs and it works as expected.
Controller: Xbox Elite Wireless Controller Series 2
Connection type: wireless
upd. I've tested controller using wire and it works well, so problem with wireless only
Steps to reproduce
Create inputs:
joy_look_up
- Joypad Axis 3 (Right Stick Up, ... - All Devices)joy_look_down
- Joypad Axis 3 (Rgith Stick Down, ... - All Devices)Add simple debug info inside
_process(delta)
:down
in chat (but expectedup
only)Video Demo
Minimal reproduction project
controller.zip
The text was updated successfully, but these errors were encountered: