mirror of
https://github.com/ppy/osu
synced 2025-01-16 02:51:20 +00:00
Merge branch 'nested-hitobject-pooling' into osu-hitobject-pooling
This commit is contained in:
commit
57ca192c8e
@ -57,6 +57,14 @@ namespace osu.Game.Rulesets.UI
|
||||
lifetimeManager.EntryBecameDead += entryBecameDead;
|
||||
}
|
||||
|
||||
protected override void LoadAsyncComplete()
|
||||
{
|
||||
base.LoadAsyncComplete();
|
||||
|
||||
// Application of hitobjects during load() may have changed their start times, so ensure the correct sorting order.
|
||||
SortInternal();
|
||||
}
|
||||
|
||||
#region Pooling support
|
||||
|
||||
public void Add(HitObjectLifetimeEntry entry) => lifetimeManager.AddEntry(entry);
|
||||
@ -163,7 +171,12 @@ namespace osu.Game.Rulesets.UI
|
||||
private void bindStartTime(DrawableHitObject hitObject)
|
||||
{
|
||||
var bindable = hitObject.StartTimeBindable.GetBoundCopy();
|
||||
bindable.BindValueChanged(_ => SortInternal());
|
||||
|
||||
bindable.BindValueChanged(_ =>
|
||||
{
|
||||
if (LoadState >= LoadState.Ready)
|
||||
SortInternal();
|
||||
});
|
||||
|
||||
startTimeMap[hitObject] = bindable;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user