mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 23:43:03 +08:00
Fix incorrect handling of reference clocks when no parent IGameplayClock
is available
This commit is contained in:
parent
04d88b8216
commit
9bc2e91de0
@ -10,6 +10,7 @@ using osu.Framework.Bindables;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Framework.Timing;
|
using osu.Framework.Timing;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Input.Handlers;
|
using osu.Game.Input.Handlers;
|
||||||
using osu.Game.Screens.Play;
|
using osu.Game.Screens.Play;
|
||||||
|
|
||||||
@ -56,6 +57,8 @@ namespace osu.Game.Rulesets.UI
|
|||||||
|
|
||||||
private IGameplayClock? parentGameplayClock;
|
private IGameplayClock? parentGameplayClock;
|
||||||
|
|
||||||
|
private IClock referenceClock = null!;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The current direction of playback to be exposed to frame stable children.
|
/// The current direction of playback to be exposed to frame stable children.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -65,18 +68,15 @@ namespace osu.Game.Rulesets.UI
|
|||||||
private int direction = 1;
|
private int direction = 1;
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(IGameplayClock? clock)
|
private void load(IGameplayClock? gameplayClock)
|
||||||
{
|
{
|
||||||
if (clock != null)
|
if (gameplayClock != null)
|
||||||
{
|
{
|
||||||
parentGameplayClock = clock;
|
parentGameplayClock = gameplayClock;
|
||||||
IsPaused.BindTo(parentGameplayClock.IsPaused);
|
IsPaused.BindTo(parentGameplayClock.IsPaused);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected override void LoadComplete()
|
referenceClock = gameplayClock ?? Clock;
|
||||||
{
|
|
||||||
base.LoadComplete();
|
|
||||||
Clock = this;
|
Clock = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +128,7 @@ namespace osu.Game.Rulesets.UI
|
|||||||
state = PlaybackState.Valid;
|
state = PlaybackState.Valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
double proposedTime = Clock.CurrentTime;
|
double proposedTime = referenceClock.CurrentTime;
|
||||||
|
|
||||||
if (FrameStablePlayback)
|
if (FrameStablePlayback)
|
||||||
// if we require frame stability, the proposed time will be adjusted to move at most one known
|
// if we require frame stability, the proposed time will be adjusted to move at most one known
|
||||||
@ -148,14 +148,14 @@ namespace osu.Game.Rulesets.UI
|
|||||||
if (state == PlaybackState.Valid && proposedTime != manualClock.CurrentTime)
|
if (state == PlaybackState.Valid && proposedTime != manualClock.CurrentTime)
|
||||||
direction = proposedTime >= manualClock.CurrentTime ? 1 : -1;
|
direction = proposedTime >= manualClock.CurrentTime ? 1 : -1;
|
||||||
|
|
||||||
double timeBehind = Math.Abs(proposedTime - Clock.CurrentTime);
|
double timeBehind = Math.Abs(proposedTime - CurrentTime);
|
||||||
|
|
||||||
IsCatchingUp.Value = timeBehind > 200;
|
IsCatchingUp.Value = timeBehind > 200;
|
||||||
WaitingOnFrames.Value = state == PlaybackState.NotValid;
|
WaitingOnFrames.Value = state == PlaybackState.NotValid;
|
||||||
|
|
||||||
manualClock.CurrentTime = proposedTime;
|
manualClock.CurrentTime = proposedTime;
|
||||||
manualClock.Rate = Math.Abs(Clock.Rate) * direction;
|
manualClock.Rate = Math.Abs(referenceClock.Rate) * direction;
|
||||||
manualClock.IsRunning = Clock.IsRunning;
|
manualClock.IsRunning = referenceClock.IsRunning;
|
||||||
|
|
||||||
// determine whether catch-up is required.
|
// determine whether catch-up is required.
|
||||||
if (state == PlaybackState.Valid && timeBehind > 0)
|
if (state == PlaybackState.Valid && timeBehind > 0)
|
||||||
@ -244,7 +244,7 @@ namespace osu.Game.Rulesets.UI
|
|||||||
|
|
||||||
public bool IsRunning => framedClock.IsRunning;
|
public bool IsRunning => framedClock.IsRunning;
|
||||||
|
|
||||||
public void ProcessFrame() => framedClock.ProcessFrame();
|
public void ProcessFrame() { }
|
||||||
|
|
||||||
public double ElapsedFrameTime => framedClock.ElapsedFrameTime;
|
public double ElapsedFrameTime => framedClock.ElapsedFrameTime;
|
||||||
|
|
||||||
@ -256,7 +256,23 @@ namespace osu.Game.Rulesets.UI
|
|||||||
|
|
||||||
#region Delegation of IGameplayClock
|
#region Delegation of IGameplayClock
|
||||||
|
|
||||||
public double TrueGameplayRate => parentGameplayClock?.TrueGameplayRate ?? 1;
|
public double TrueGameplayRate
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
double baseRate = Rate;
|
||||||
|
|
||||||
|
foreach (double adjustment in NonGameplayAdjustments)
|
||||||
|
{
|
||||||
|
if (Precision.AlmostEquals(adjustment, 0))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
baseRate /= adjustment;
|
||||||
|
}
|
||||||
|
|
||||||
|
return baseRate;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public double? StartTime => parentGameplayClock?.StartTime;
|
public double? StartTime => parentGameplayClock?.StartTime;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user