-
-
Notifications
You must be signed in to change notification settings - Fork 532
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
Make emscripten port default to 85 FPS, non-V-sync #675
Comments
Hmm, using It's unfortunate that player physics are affected by rendering framerate. It seems to me that pmove_fixed is the right solution and any side effects ought to be fixable, though that might be a big job. |
Coming in here through the referenced SDL issue to say this: you want to use requestAnimationFrame unconditionally, and be willing to deal with the browser deciding to run your mainloop less when the window is minimized, or maybe even just not in the foreground, if it feels like doing that to you. It might decide to not run it at all, too. Using setTimeout is a losing strategy: you will not get a consistent framerate, or even necessarily a good framerate at all...modern browsers tend to coalesce timers together for efficiency, which is probably a good idea for web browsing in general, but disastrous when you're trying to run a game's main loop off of it. Basically, you shouldn't be aiming for any specific framerate, because you have very little control over it. Generally requestAnimationFrame is attached to vsync and runs at the refresh rate of the user's display, and that's the thing you should be aiming for. |
Thanks for fixing initial V-sync setting in SDL. I'll drop the idea of using setTimeout. |
Currently the emscripten port starts out using V-sync (requestAnimationFrame) due to a design issue in emscripten that emscripten_set_main_loop_timing() cannot be set before emscripten_set_main_loop() (libsdl-org/SDL#9969 / emscripten-core/emscripten#7100). After running the ioquake3
vid_restart
command, V-sync is disabled and it runs at 90 FPS according tocg_drawFPS 1
.Using V-sync may end up being explicitly enabled by #672.
The player movement is tied to the client framerate so I'm not sure if using 60 FPS V-sync by default is a good idea.
If I remember correctly running at 60 FPS has a lower jump height than default com_maxfps 85. (I don't remember specifically where this is relevant.) It's preferable for the client to use com_maxfps 125 for the highest jump height which is known to effect many places (such as the mega health in q3dm13).
pmove_fixed 1
avoids player movement being client framerate dependent but it may have other side effects? (This is all kind of player/server specific that ideally the emscripten port should behave the same as other platforms in my opinion.)It may be possible to use emscripten_set_main_loop_timing() to target com_maxfps instead of sleeping in Com_Frame() to reduce overhead in a web browser while not affecting player movement. This would need to be set after creating the window (as SDL changes it via emscripten's egl implementation), when the com_maxfps cvar changes, and emscripten_set_main_loop(). r_swapInterval could enable using requestAnimationFrame (as already happens through SDL).
The text was updated successfully, but these errors were encountered: