mirror of
https://github.com/ppy/osu.git
synced 2025-01-19 11:32:54 +08:00
Merge pull request #23943 from peppy/fps-nan
Attempt to fix rare NaN fps display
This commit is contained in:
commit
e77cbc395c
@ -167,9 +167,12 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
|
||||||
|
double elapsedDrawFrameTime = drawClock.ElapsedFrameTime;
|
||||||
|
double elapsedUpdateFrameTime = updateClock.ElapsedFrameTime;
|
||||||
|
|
||||||
// If the game goes into a suspended state (ie. debugger attached or backgrounded on a mobile device)
|
// If the game goes into a suspended state (ie. debugger attached or backgrounded on a mobile device)
|
||||||
// we want to ignore really long periods of no processing.
|
// we want to ignore really long periods of no processing.
|
||||||
if (updateClock.ElapsedFrameTime > 10000)
|
if (elapsedUpdateFrameTime > 10000)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mainContent.Width = Math.Max(mainContent.Width, counters.DrawWidth);
|
mainContent.Width = Math.Max(mainContent.Width, counters.DrawWidth);
|
||||||
@ -178,17 +181,17 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
// frame limiter (we want to show the FPS as it's changing, even if it isn't an outlier).
|
// frame limiter (we want to show the FPS as it's changing, even if it isn't an outlier).
|
||||||
bool aimRatesChanged = updateAimFPS();
|
bool aimRatesChanged = updateAimFPS();
|
||||||
|
|
||||||
bool hasUpdateSpike = displayedFrameTime < spike_time_ms && updateClock.ElapsedFrameTime > spike_time_ms;
|
bool hasUpdateSpike = displayedFrameTime < spike_time_ms && elapsedUpdateFrameTime > spike_time_ms;
|
||||||
// use elapsed frame time rather then FramesPerSecond to better catch stutter frames.
|
// use elapsed frame time rather then FramesPerSecond to better catch stutter frames.
|
||||||
bool hasDrawSpike = displayedFpsCount > (1000 / spike_time_ms) && drawClock.ElapsedFrameTime > spike_time_ms;
|
bool hasDrawSpike = displayedFpsCount > (1000 / spike_time_ms) && elapsedDrawFrameTime > spike_time_ms;
|
||||||
|
|
||||||
const float damp_time = 100;
|
const float damp_time = 100;
|
||||||
|
|
||||||
displayedFrameTime = Interpolation.DampContinuously(displayedFrameTime, updateClock.ElapsedFrameTime, hasUpdateSpike ? 0 : damp_time, updateClock.ElapsedFrameTime);
|
displayedFrameTime = Interpolation.DampContinuously(displayedFrameTime, elapsedUpdateFrameTime, hasUpdateSpike ? 0 : damp_time, elapsedUpdateFrameTime);
|
||||||
|
|
||||||
if (hasDrawSpike)
|
if (hasDrawSpike)
|
||||||
// show spike time using raw elapsed value, to account for `FramesPerSecond` being so averaged spike frames don't show.
|
// show spike time using raw elapsed value, to account for `FramesPerSecond` being so averaged spike frames don't show.
|
||||||
displayedFpsCount = 1000 / drawClock.ElapsedFrameTime;
|
displayedFpsCount = 1000 / elapsedDrawFrameTime;
|
||||||
else
|
else
|
||||||
displayedFpsCount = Interpolation.DampContinuously(displayedFpsCount, drawClock.FramesPerSecond, damp_time, Time.Elapsed);
|
displayedFpsCount = Interpolation.DampContinuously(displayedFpsCount, drawClock.FramesPerSecond, damp_time, Time.Elapsed);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user