Calculate real position for judgement lines

This commit is contained in:
Andrei Zavatski 2019-08-11 18:04:54 +03:00
parent 0a255fe4d1
commit 2a35c3c3e2
2 changed files with 27 additions and 4 deletions

View File

@ -9,6 +9,10 @@ using osuTK.Graphics;
using osuTK;
using osu.Framework.Graphics.Sprites;
using System.Collections.Generic;
using osu.Game.Rulesets.Objects;
using osu.Game.Beatmaps;
using osu.Framework.Bindables;
using osu.Framework.Allocation;
namespace osu.Game.Screens.Play.HUD
{
@ -18,6 +22,11 @@ namespace osu.Game.Screens.Play.HUD
private const int bar_height = 250;
private const int spacing = 3;
public HitWindows HitWindows { get; set; }
[Resolved]
private Bindable<WorkingBeatmap> beatmap { get; set; }
private readonly bool mirrored;
private readonly SpriteIcon arrow;
private readonly List<double> judgementOffsets = new List<double>();
@ -47,6 +56,12 @@ namespace osu.Game.Screens.Play.HUD
};
}
protected override void LoadComplete()
{
base.LoadComplete();
HitWindows.SetDifficulty(beatmap.Value.BeatmapInfo.BaseDifficulty.OverallDifficulty);
}
public void OnNewJudgement(JudgementResult judgement)
{
Container judgementLine;
@ -56,7 +71,7 @@ namespace osu.Game.Screens.Play.HUD
judgementLine.FadeOut(5000, Easing.OutQuint);
judgementLine.Expire();
arrow.MoveToY(calculateArrowPosition(judgement) / bar_height, 500, Easing.OutQuint);
arrow.MoveToY(getRelativeJudgementPosition(calculateArrowPosition(judgement)), 500, Easing.OutQuint);
}
protected virtual Container CreateJudgementLine(JudgementResult judgement) => new CircularContainer
@ -66,7 +81,7 @@ namespace osu.Game.Screens.Play.HUD
Masking = true,
Size = new Vector2(10, 2),
RelativePositionAxes = Axes.Y,
Y = (float)judgement.TimeOffset / bar_height,
Y = getRelativeJudgementPosition(judgement.TimeOffset),
X = mirrored ? spacing : -spacing,
Child = new Box
{
@ -75,7 +90,9 @@ namespace osu.Game.Screens.Play.HUD
}
};
private float calculateArrowPosition(JudgementResult judgement)
private float getRelativeJudgementPosition(double value) => (float)(value / HitWindows.Miss);
private double calculateArrowPosition(JudgementResult judgement)
{
if (judgementOffsets.Count > 5)
judgementOffsets.RemoveAt(0);
@ -87,7 +104,7 @@ namespace osu.Game.Screens.Play.HUD
foreach (var offset in judgementOffsets)
offsets += offset;
return (float)offsets / judgementOffsets.Count;
return offsets / judgementOffsets.Count;
}
}
}

View File

@ -277,10 +277,16 @@ namespace osu.Game.Screens.Play
HealthDisplay?.Current.BindTo(processor.Health);
if (LeftAccuracyBar != null)
{
processor.NewJudgement += LeftAccuracyBar.OnNewJudgement;
LeftAccuracyBar.HitWindows = processor.CreateHitWindows();
}
if (RightAccuracyBar != null)
{
processor.NewJudgement += RightAccuracyBar.OnNewJudgement;
RightAccuracyBar.HitWindows = processor.CreateHitWindows();
}
if (HealthDisplay is StandardHealthDisplay shd)
processor.NewJudgement += shd.Flash;