osu/osu.Game.Rulesets.Catch/UI/CatchPlayfield.cs

101 lines
3.7 KiB
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.
2018-04-13 09:19:50 +00:00
using osu.Framework.Allocation;
2018-04-13 09:19:50 +00:00
using osu.Framework.Graphics;
using osu.Game.Beatmaps;
using osu.Game.Rulesets.Catch.Objects;
using osu.Game.Rulesets.Catch.Objects.Drawables;
2018-04-13 09:19:50 +00:00
using osu.Game.Rulesets.Judgements;
using osu.Game.Rulesets.Objects.Drawables;
using osu.Game.Rulesets.UI.Scrolling;
using osuTK;
2018-04-13 09:19:50 +00:00
namespace osu.Game.Rulesets.Catch.UI
{
public class CatchPlayfield : ScrollingPlayfield
{
/// <summary>
/// The width of the playfield.
/// The horizontal movement of the catcher is confined in the area of this width.
/// </summary>
public const float WIDTH = 512;
/// <summary>
/// The center position of the playfield.
/// </summary>
public const float CENTER_X = WIDTH / 2;
2018-04-13 09:19:50 +00:00
public override bool ReceivePositionalInputAt(Vector2 screenSpacePos) =>
// only check the X position; handle all vertical space.
base.ReceivePositionalInputAt(new Vector2(screenSpacePos.X, ScreenSpaceDrawQuad.Centre.Y));
internal Catcher Catcher { get; private set; }
2021-07-19 10:44:40 +00:00
internal CatcherArea CatcherArea { get; private set; }
2021-07-19 10:44:40 +00:00
2021-07-19 12:05:36 +00:00
private readonly BeatmapDifficulty difficulty;
public CatchPlayfield(BeatmapDifficulty difficulty)
{
this.difficulty = difficulty;
}
[BackgroundDependencyLoader]
private void load()
2018-04-13 09:19:50 +00:00
{
var droppedObjectContainer = new DroppedObjectContainer();
2021-07-19 10:44:40 +00:00
Catcher = new Catcher(droppedObjectContainer, difficulty)
{
2021-07-19 10:44:40 +00:00
X = CENTER_X
};
2018-04-13 09:19:50 +00:00
AddRangeInternal(new[]
2018-04-13 09:19:50 +00:00
{
droppedObjectContainer,
2021-07-19 10:44:40 +00:00
Catcher.CreateProxiedContent(),
HitObjectContainer.CreateProxy(),
// This ordering (`CatcherArea` before `HitObjectContainer`) is important to
// make sure the up-to-date catcher position is used for the catcher catching logic of hit objects.
2021-07-19 10:44:40 +00:00
CatcherArea = new CatcherArea
{
Anchor = Anchor.BottomLeft,
Origin = Anchor.TopLeft,
Catcher = Catcher,
2021-07-19 10:44:40 +00:00
},
HitObjectContainer,
});
RegisterPool<Droplet, DrawableDroplet>(50);
RegisterPool<TinyDroplet, DrawableTinyDroplet>(50);
RegisterPool<Fruit, DrawableFruit>(100);
RegisterPool<Banana, DrawableBanana>(100);
RegisterPool<JuiceStream, DrawableJuiceStream>(10);
RegisterPool<BananaShower, DrawableBananaShower>(2);
}
protected override void LoadComplete()
{
base.LoadComplete();
2020-11-30 06:22:55 +00:00
// these subscriptions need to be done post constructor to ensure externally bound components have a chance to populate required fields (ScoreProcessor / ComboAtJudgement in this case).
NewResult += onNewResult;
RevertResult += onRevertResult;
2020-11-21 06:20:33 +00:00
}
protected override void OnNewDrawableHitObject(DrawableHitObject d)
{
((DrawableCatchHitObject)d).CheckPosition = checkIfWeCanCatch;
2018-04-13 09:19:50 +00:00
}
private bool checkIfWeCanCatch(CatchHitObject obj) => Catcher.CanCatch(obj);
2018-04-13 09:19:50 +00:00
private void onNewResult(DrawableHitObject judgedObject, JudgementResult result)
2020-09-12 20:39:06 +00:00
=> CatcherArea.OnNewResult((DrawableCatchHitObject)judgedObject, result);
private void onRevertResult(DrawableHitObject judgedObject, JudgementResult result)
2020-09-12 20:39:06 +00:00
=> CatcherArea.OnRevertResult((DrawableCatchHitObject)judgedObject, result);
2018-04-13 09:19:50 +00:00
}
}