Skip to content
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

Mouse mapping support #741

Merged
merged 63 commits into from
Jan 3, 2025
Merged

Conversation

lightmanLP
Copy link
Contributor

@lightmanLP lightmanLP commented Dec 11, 2024

Support for binding mouse keys

  • update dxgi mouse capture to make it compatible with sdl
  • fix fullscreen dxgi mouse capture behavior

co-authored-by: @lilacLunatic

@lightmanLP lightmanLP force-pushed the feat/mouse-mapping branch 2 times, most recently from df0a498 to 9a9c219 Compare December 18, 2024 05:19
@lightmanLP lightmanLP marked this pull request as ready for review December 18, 2024 06:21
Copy link
Collaborator

@briaguya-ai briaguya-ai left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

overall stuff is looking good! left a few comments (some you already had todos for)

i wasn't able to test this out locally (now that the resourcefilter stuff landed it seems the soh side of that will need to land before testing this is straightforward), but i was hoping to test out what the mapping experience - specifically what happens when this popup is visible

image

and someone clicks on (or misses when trying to click on) the cancel button

src/controller/controldeck/ControlDeck.cpp Show resolved Hide resolved
src/controller/controldeck/ControlDeck.cpp Outdated Show resolved Hide resolved
src/window/MouseMeta.h Outdated Show resolved Hide resolved
src/graphic/Fast3D/gfx_dxgi.cpp Outdated Show resolved Hide resolved
src/graphic/Fast3D/gfx_dxgi.cpp Show resolved Hide resolved
@lightmanLP
Copy link
Contributor Author

Cancel button click should work without any problems, you can test it here https://github.com/lightmanLP/2ship2harkinian/tree/mouse-mapping-test
P.S. slightly outdated because of release-version LUS

@briaguya-ai
Copy link
Collaborator

briaguya-ai commented Dec 18, 2024

Cancel button click should work without any problems, you can test it here https://github.com/lightmanLP/2ship2harkinian/tree/mouse-mapping-test P.S. slightly outdated because of release-version LUS

the cancel button does seem to work as expected, but i am still somewhat concerned about always capturing mouse when reading input for mappings

accidental mouse inputs are decently common, so having some safeguards would be nice

one example i noticed when testing this out was if someone accidentally double clicks on an existing mapping it'll replace the mapping

Screencast.From.2024-12-18.10-13-50.mp4

i'd like to hear what others think about this (is it a problem we should worry about? if it's a problem we should worry about, what would a good solution be?)

@lightmanLP
Copy link
Contributor Author

lightmanLP commented Dec 18, 2024

one example i noticed when testing this out was if someone accidentally double clicks on an existing mapping it'll replace the mapping

It might be fixed by spawning binding popup offsetted from cursor and checking for cursor to be in popup boundaries for mouse binding

@briaguya-ai
Copy link
Collaborator

It might be fixed by spawning binding popup offsetted from cursor and checking for cursor to be in popup boundaries for mouse binding

that seems reasonable to me!

it doesn't solve the "tried to click the cancel button and missed" problem but that's probably fine - if people start reporting that as a bug once this ships we can look into other solutions

@lightmanLP lightmanLP force-pushed the feat/mouse-mapping branch 5 times, most recently from f0f7132 to a272e1a Compare December 25, 2024 02:55
@lightmanLP
Copy link
Contributor Author

lightmanLP commented Dec 27, 2024

It might be fixed by spawning binding popup offsetted from cursor and checking for cursor to be in popup boundaries for mouse binding

Implemented
For testing purposes: https://github.com/lightmanLP/2ship2harkinian/actions/runs/12521779818

@lightmanLP
Copy link
Contributor Author

Made version of 2S2H with latest LUS and mouse mapping on top
HarbourMasters/2ship2harkinian#910

@lightmanLP lightmanLP force-pushed the feat/mouse-mapping branch 3 times, most recently from 7d5a185 to dcbda99 Compare January 2, 2025 08:30
@briaguya-ai
Copy link
Collaborator

@lightmanLP I just tested the latest build from https://github.com/lightmanLP/2ship2harkinian/actions/workflows/main.yml (387fb85) and it seems like using the mouse in the popped out input editor is completely broken (but it's working perfectly in the esc menu)

is that something you've tested/been able to repro?

@lightmanLP
Copy link
Contributor Author

lightmanLP commented Jan 3, 2025

Just downloaded latest, everything seems fine for me. Can you explain what exactly happened?
Only issue with popped out editor that I bumped in always is mapping window doesn't work when it's outside the game window (and its known issue for keyboard, same for mouse).

@briaguya-ai
Copy link
Collaborator

after trying again i was unable to reproduce the issue

Copy link
Collaborator

@briaguya-ai briaguya-ai left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

:shipit:

@briaguya-ai briaguya-ai merged commit 78d951e into Kenix3:main Jan 3, 2025
5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants