mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 22:32:55 +08:00
Remove unnecessary encapsulation workaround
The new implementation of `DecouplingClock` will not mutate the underlying clock in any way (unless attempting to start it when approaching from a negative time value). This should be quite safe as a result.
This commit is contained in:
parent
21a2e27e5f
commit
5f634f2812
@ -142,10 +142,7 @@ namespace osu.Game.Beatmaps
|
|||||||
|
|
||||||
#region Delegation of IAdjustableClock / ISourceChangeableClock to decoupled clock.
|
#region Delegation of IAdjustableClock / ISourceChangeableClock to decoupled clock.
|
||||||
|
|
||||||
public void ChangeSource(IClock? source)
|
public void ChangeSource(IClock? source) => decoupledTrack.ChangeSource(source);
|
||||||
{
|
|
||||||
decoupledTrack.ChangeSource(source as Track ?? new TrackVirtual(60000));
|
|
||||||
}
|
|
||||||
|
|
||||||
public IClock Source => decoupledTrack.Source;
|
public IClock Source => decoupledTrack.Source;
|
||||||
|
|
||||||
|
@ -441,16 +441,7 @@ namespace osu.Game
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onTrackChanged(WorkingBeatmap beatmap, TrackChangeDirection direction)
|
private void onTrackChanged(WorkingBeatmap beatmap, TrackChangeDirection direction) => beatmapClock.ChangeSource(beatmap.Track);
|
||||||
{
|
|
||||||
// FramedBeatmapClock uses a decoupled clock internally which will mutate the source if it is an `IAdjustableClock`.
|
|
||||||
// We don't want this for now, as the intention of beatmapClock is to be a read-only source for beat sync components.
|
|
||||||
//
|
|
||||||
// Encapsulating in a FramedClock will avoid any mutations.
|
|
||||||
var framedClock = new FramedClock(beatmap.Track);
|
|
||||||
|
|
||||||
beatmapClock.ChangeSource(framedClock);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected virtual void InitialiseFonts()
|
protected virtual void InitialiseFonts()
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user