-
Notifications
You must be signed in to change notification settings - Fork 3.3k
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 scroll delta is not scaled properly #6283
Comments
I made this HTML to display and test the behavior:
|
I've encountered the same problem while using SDL API: Y delta is different about ~30 times between Firefox and Chrome. The Firefox values are similar to what I get when running native SDL on Linux. I've also came across this 4-year old issue. Looks like it was closed without normalizing the values between browsers. |
Having this issue aswell |
Looks like the specific issue is in line 568 of
I just found this solution from facebook. They essentially convert all values into pixels. I would suggest that we also return those estimated pixels by default. Specific libraries like |
Does the fix apply to SDL2 too? I have this same issue now with 1.39.3. |
@malytomas Sorry to disappoint. This was really just a legacy patch. SDL1 and GLFW2 should work, but neither GLFW3 nor SDL2 are affected by this. This also only supports vertical scrolling. I think the html5 api would be the place to fix issues with SDL2. emscripten/src/library_html5.js Lines 552 to 617 in 1abc0c7
|
Are there any updates on a SDL2 fix? This is causing major issues for us |
I'm not aware of someone working on it. cc @Daft-Freak who might remember more though. If someone is interested to investigate and work on a patch for this, let me know if there is anything I can do to speed that along. |
I think I remember this being mentioned at some point, but doesn't look like anything was implemented... Looks like we need to check |
@Daft-Freak is there a library / implementation that handles that correctly? |
Having the same issue, a super hacky fix, for now, it's to normalize everything [-1.0, 1.0]. Which it's pants. But at least it "works" for us somehow. I do not understand were the root of the problem is, in the GLFW and SDL callbacks? Or in the general HTML5 wheel handling code? I won't mind having a go if you can confirm where exactly the issue arises. |
@ziocleto i'm not sure either why this can't be fixed. This is literally breaking our entire application on some browsers |
@feliwir Me neither, IIRC I had a go to try to understand the issue but I really gave up as it seems nobody really knows all the details of this mess. And yes, even for us, it broke everything, well it still does, so annoying... If you have any updates, let us know! |
@ziocleto i investigated a bit further and found out that the deltaMode is different for Chrome & Firefox (thanks @Daft-Freak ).
However this will probably break for Retinna etc. Can't we just pass the deltaMode to the callback aswell? |
I said exactly this in my very first report 2 years ago in the top of this very issue report if you care to read it... |
Indeed, thanks to @alexhultman aswell, but can we fix this now? |
You need to know the height of a "row" and scale it accordingly. That's in the initial report. [On] Firefox [emscripten] treats the input given as "rows" as if they were pixels. That's why the scrolling is wildly incorrect. I guess you need to read the font metrics or the font-size or something like that. |
@alexhultman well, we display text ourselves (with WebGL), so it would be enough for us to get a notification by the SDL port that this is LINES or PIXELS, so we can handle the difference on our side. Maybe we could add new wheel types? |
I did look at this for SDL2, but the values seem to vary between platforms. (And possibly system settings?) To get scroll events matching native on Windows, I needed /3 for |
BTW As I see that you guys are talking about SDL, I do not think the problem is related to SDL per se, we use GLFW for example, so fixing it should be agnostic from the graphics framework. |
Hmm, SDL2 should probably be an issue in the SDL2 repo. (The fix would be in SDL as it's using the low-level HTML5 API). You could even argue that it doesn't need fixed as the docs for |
This issue has been automatically marked as stale because there has been no activity in the past year. It will be closed automatically if no further activity occurs in the next 30 days. Feel free to re-open at any time if this issue is still relevant. |
I've posted PR to the SDL2 port which fixes for me: emscripten-ports/SDL2#154 |
Thanks @thomasballinger ! If people can test that PR and verify it works on their codebases, and on multiple browsers, that would help move this forward. |
One way to test is to make these changes to
(I've updated the hash 3x now, you can also set the hash to '')
I've tried this with https://play-endless-web.com/ (deployed version does not have the fix) in Firefox and Chrome and it feels much better to me. |
Even in situations where we get PIXELS, the delta values still vary wildly across browser/OS combinations (even across the same browser in different OSes). Related: |
I've done some digging and I think this is true for all scrolling in all libraries.
Using GLFW to listen to scroll events (glfwSetScrollCallback) gives me two doubles: Y and X delta. These are majorly differing between Firefox and Chrome (because as I have found, you should scale the delta according to if you get PIXELS or LINES).
In library_glfw.js, glfwInit function you listen to 'wheel' event (and others), handler is GLFW.onMouseWheel. There you call Browser.getMouseWheelDelta which for the 'wheel' event simply returns deltaY. Then this delta is just passed up to GLFW handlers.
What needs to be done is to properly handle the WheelEvent.deltaMode which can be DOM_DELTA_PIXEL or DOM_DELTA_LINE or even DOM_DELTA_PAGE.
When Firefox gives delta in LINES and Chrome gives delta in PIXELS there's a major inconsistency for apps run in those two browsers. Browser.getMouseWheelDelta is used by all libraries it seems to this issue should affect all scrolling.
The text was updated successfully, but these errors were encountered: