1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-17 07:42:54 +08:00
osu-lazer/osu.Game/Modes/UI/HitRenderer.cs

117 lines
3.5 KiB
C#
Raw Normal View History

// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
2016-09-02 18:25:13 +08:00
2016-11-14 16:23:33 +08:00
using System;
2016-09-02 18:25:13 +08:00
using System.Collections.Generic;
2016-11-14 16:23:33 +08:00
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Graphics;
2016-09-02 18:25:13 +08:00
using osu.Framework.Graphics.Containers;
2016-11-14 17:03:20 +08:00
using osu.Game.Modes.Objects;
2016-11-14 18:49:29 +08:00
using osu.Game.Modes.Objects.Drawables;
2017-02-09 13:56:39 +08:00
using osu.Game.Beatmaps;
using osu.Game.Screens.Play;
using OpenTK;
2016-09-02 18:25:13 +08:00
2016-11-14 17:54:24 +08:00
namespace osu.Game.Modes.UI
2016-09-02 18:25:13 +08:00
{
public abstract class HitRenderer : Container
{
public event Action<JudgementInfo> OnJudgement;
2016-11-29 22:59:56 +08:00
public event Action OnAllJudged;
internal readonly PlayerInputManager InputManager = new PlayerInputManager();
/// <summary>
/// A function to convert coordinates from gamefield to screen space.
/// </summary>
public abstract Func<Vector2, Vector2> MapPlayfieldToScreenSpace { get; }
2017-03-06 12:59:11 +08:00
public abstract bool AllObjectsJudged { get; }
2017-02-28 19:14:48 +08:00
2016-11-29 22:59:56 +08:00
protected void TriggerOnJudgement(JudgementInfo j)
{
OnJudgement?.Invoke(j);
if (AllObjectsJudged)
OnAllJudged?.Invoke();
}
2017-03-06 12:59:11 +08:00
}
2016-11-02 13:07:20 +08:00
2017-03-06 12:59:11 +08:00
public abstract class HitRenderer<TObject> : HitRenderer
where TObject : HitObject
{
private List<TObject> objects;
2016-11-02 13:07:20 +08:00
2017-03-06 12:59:11 +08:00
protected Playfield<TObject> Playfield;
public override Func<Vector2, Vector2> MapPlayfieldToScreenSpace => Playfield.ScaledContent.ToScreenSpace;
2017-03-06 12:59:11 +08:00
public override bool AllObjectsJudged => Playfield.HitObjects.Children.First()?.Judgement.Result != null; //reverse depth sort means First() instead of Last().
public IEnumerable<DrawableHitObject> DrawableObjects => Playfield.HitObjects.Children;
2017-02-09 13:56:39 +08:00
public Beatmap Beatmap
{
set
{
objects = Convert(value);
if (IsLoaded)
loadObjects();
}
}
2017-03-06 12:59:11 +08:00
protected abstract Playfield<TObject> CreatePlayfield();
2017-03-06 12:59:11 +08:00
protected abstract HitObjectConverter<TObject> Converter { get; }
2017-03-06 12:59:11 +08:00
protected virtual List<TObject> Convert(Beatmap beatmap) => Converter.Convert(beatmap);
2017-03-07 09:59:19 +08:00
protected HitRenderer()
{
RelativeSizeAxes = Axes.Both;
InputManager.Add(content = new Container
{
RelativeSizeAxes = Axes.Both,
Children = new[]
{
Playfield = CreatePlayfield(),
}
});
AddInternal(InputManager);
}
protected override Container<Drawable> Content => content;
private Container content;
[BackgroundDependencyLoader]
private void load()
{
loadObjects();
}
private void loadObjects()
{
if (objects == null) return;
2017-03-06 12:59:11 +08:00
foreach (TObject h in objects)
{
2017-03-06 12:59:11 +08:00
DrawableHitObject<TObject> drawableObject = GetVisualRepresentation(h);
if (drawableObject == null) continue;
drawableObject.OnJudgement += onJudgement;
2016-11-02 13:07:20 +08:00
Playfield.Add(drawableObject);
}
2017-02-10 13:16:23 +08:00
Playfield.PostProcess();
}
2017-03-06 12:59:11 +08:00
private void onJudgement(DrawableHitObject<TObject> o, JudgementInfo j) => TriggerOnJudgement(j);
2017-03-06 12:59:11 +08:00
protected abstract DrawableHitObject<TObject> GetVisualRepresentation(TObject h);
2016-09-02 18:25:13 +08:00
}
}