osu/osu.Game/Rulesets/Edit/DrawableEditorRulesetWrapper.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

104 lines
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Extensions.ObjectExtensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.Objects;
using osu.Game.Rulesets.UI;
2019-08-29 07:06:40 +00:00
using osu.Game.Screens.Edit;
namespace osu.Game.Rulesets.Edit
{
/// <summary>
/// A wrapper for a <see cref="DrawableRuleset{TObject}"/>. Handles adding visual representations of <see cref="HitObject"/>s to the underlying <see cref="DrawableRuleset{TObject}"/>.
/// </summary>
2021-04-26 06:37:42 +00:00
internal partial class DrawableEditorRulesetWrapper<TObject> : CompositeDrawable
where TObject : HitObject
{
2019-08-29 09:12:29 +00:00
public Playfield Playfield => drawableRuleset.Playfield;
2019-03-20 02:22:34 +00:00
private readonly DrawableRuleset<TObject> drawableRuleset;
2019-08-29 07:06:40 +00:00
[Resolved]
private EditorBeatmap beatmap { get; set; } = null!;
2019-08-29 07:06:40 +00:00
2021-04-26 06:37:42 +00:00
public DrawableEditorRulesetWrapper(DrawableRuleset<TObject> drawableRuleset)
{
2019-03-20 02:22:34 +00:00
this.drawableRuleset = drawableRuleset;
2019-08-29 09:12:29 +00:00
RelativeSizeAxes = Axes.Both;
2019-03-20 02:22:34 +00:00
InternalChild = drawableRuleset;
}
[BackgroundDependencyLoader]
private void load()
{
drawableRuleset.FrameStablePlayback = false;
Playfield.DisplayJudgements.Value = false;
}
[Resolved]
private IEditorChangeHandler? changeHandler { get; set; }
2019-08-29 07:06:40 +00:00
protected override void LoadComplete()
{
2019-08-29 07:06:40 +00:00
base.LoadComplete();
2019-08-29 07:06:40 +00:00
beatmap.HitObjectAdded += addHitObject;
beatmap.HitObjectRemoved += removeHitObject;
if (changeHandler != null)
{
// for now only regenerate replay on a finalised state change, not HitObjectUpdated.
changeHandler.OnStateChange += () => Scheduler.AddOnce(regenerateAutoplay);
}
else
{
beatmap.HitObjectUpdated += _ => Scheduler.AddOnce(regenerateAutoplay);
}
Scheduler.AddOnce(regenerateAutoplay);
2019-08-29 07:06:40 +00:00
}
private void regenerateAutoplay()
{
var autoplayMod = drawableRuleset.Mods.OfType<ModAutoplay>().Single();
drawableRuleset.SetReplayScore(autoplayMod.CreateScoreFromReplayData(drawableRuleset.Beatmap, drawableRuleset.Mods));
}
2019-08-29 07:06:40 +00:00
private void addHitObject(HitObject hitObject)
{
2020-11-13 08:08:20 +00:00
drawableRuleset.AddHitObject((TObject)hitObject);
2019-03-20 02:22:34 +00:00
drawableRuleset.Playfield.PostProcess();
}
2018-10-18 07:36:06 +00:00
2019-08-29 07:06:40 +00:00
private void removeHitObject(HitObject hitObject)
2018-10-18 07:36:06 +00:00
{
2020-11-13 08:08:20 +00:00
drawableRuleset.RemoveHitObject((TObject)hitObject);
2019-03-20 02:22:34 +00:00
drawableRuleset.Playfield.PostProcess();
2018-10-18 07:36:06 +00:00
}
2019-08-29 07:31:40 +00:00
2019-11-11 04:04:38 +00:00
public override bool PropagatePositionalInputSubTree => false;
public override bool PropagateNonPositionalInputSubTree => false;
2019-08-29 09:12:29 +00:00
public PlayfieldAdjustmentContainer CreatePlayfieldAdjustmentContainer() => drawableRuleset.CreatePlayfieldAdjustmentContainer();
2019-08-29 07:31:40 +00:00
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
if (beatmap.IsNotNull())
2019-08-29 07:31:40 +00:00
{
beatmap.HitObjectAdded -= addHitObject;
beatmap.HitObjectRemoved -= removeHitObject;
}
}
}
}