1
0
mirror of https://github.com/ppy/osu.git synced 2024-09-23 02:07:24 +08:00
osu-lazer/osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs

154 lines
5.3 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:50:22 +08:00
using osu.Framework.Allocation;
using osu.Framework.MathUtils;
using osu.Framework.Graphics;
using osu.Game.Beatmaps;
using osu.Game.Beatmaps.Timing;
2016-11-14 18:49:29 +08:00
using osu.Game.Modes.Objects.Drawables;
2017-04-01 22:59:44 +08:00
using osu.Game.Modes.Objects.Types;
2017-03-31 15:20:31 +08:00
using osu.Game.Modes.Replays;
using osu.Game.Modes.Scoring;
using osu.Game.Modes.Taiko.Beatmaps;
using osu.Game.Modes.Taiko.Judgements;
2016-11-14 17:54:24 +08:00
using osu.Game.Modes.Taiko.Objects;
2017-04-01 22:59:44 +08:00
using osu.Game.Modes.Taiko.Objects.Drawable;
2017-03-31 15:20:31 +08:00
using osu.Game.Modes.Taiko.Replays;
using osu.Game.Modes.Taiko.Scoring;
2016-11-14 17:54:24 +08:00
using osu.Game.Modes.UI;
2017-04-03 13:22:22 +08:00
using osu.Game.Modes.Replays;
using osu.Game.Modes.Taiko.Replays;
2016-09-02 18:50:22 +08:00
2016-11-14 17:54:24 +08:00
namespace osu.Game.Modes.Taiko.UI
2016-09-02 18:50:22 +08:00
{
public class TaikoHitRenderer : HitRenderer<TaikoHitObject, TaikoJudgement>
2016-09-02 18:50:22 +08:00
{
public TaikoHitRenderer(WorkingBeatmap beatmap)
: base(beatmap)
{
}
[BackgroundDependencyLoader]
private void load()
{
loadBarLines();
}
private void loadBarLines()
{
var taikoPlayfield = Playfield as TaikoPlayfield;
if (taikoPlayfield == null)
return;
TaikoHitObject lastObject = Beatmap.HitObjects[Beatmap.HitObjects.Count - 1];
// ReSharper disable once SuspiciousTypeConversion.Global (will be fixed with hitobjects)
double lastHitTime = 1 + (lastObject as IHasEndTime)?.EndTime ?? lastObject.StartTime;
var timingPoints = Beatmap.TimingInfo.ControlPoints.FindAll(cp => cp.TimingChange);
if (timingPoints == null || timingPoints.Count == 0)
return;
int currentIndex = 0;
while (currentIndex < timingPoints.Count && Precision.AlmostEquals(timingPoints[currentIndex].BeatLength, 0))
currentIndex++;
double time = timingPoints[currentIndex].Time;
double measureLength = timingPoints[currentIndex].BeatLength * (int)timingPoints[currentIndex].TimeSignature;
// Find the bar line time closest to 0
time -= measureLength * (int)(time / measureLength);
// Always start barlines from a positive time
while (time < 0)
time += measureLength;
int currentBeat = 0;
while (time <= lastHitTime)
{
ControlPoint current = timingPoints[currentIndex];
if (time > current.Time || current.OmitFirstBarLine)
{
bool isMajor = currentBeat % (int)current.TimeSignature == 0;
2017-04-01 22:59:44 +08:00
var barLine = new BarLine
{
StartTime = time,
};
barLine.ApplyDefaults(Beatmap.TimingInfo, Beatmap.BeatmapInfo.Difficulty);
taikoPlayfield.AddBarLine(isMajor ? new DrawableMajorBarLine(barLine) : new DrawableBarLine(barLine));
currentBeat++;
}
double bl = current.BeatLength;
if (bl < 800)
bl *= (int)current.TimeSignature;
time += bl;
if (currentIndex + 1 >= timingPoints.Count || time < timingPoints[currentIndex + 1].Time)
continue;
currentBeat = 0;
currentIndex++;
time = timingPoints[currentIndex].Time;
}
}
public override ScoreProcessor CreateScoreProcessor() => new TaikoScoreProcessor(this);
2017-03-17 12:33:48 +08:00
protected override IBeatmapConverter<TaikoHitObject> CreateBeatmapConverter() => new TaikoBeatmapConverter();
2017-03-17 12:33:48 +08:00
protected override IBeatmapProcessor<TaikoHitObject> CreateBeatmapProcessor() => new TaikoBeatmapProcessor();
2016-09-02 18:50:22 +08:00
protected override Playfield<TaikoHitObject, TaikoJudgement> CreatePlayfield() => new TaikoPlayfield
{
Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft
};
2016-09-02 18:50:22 +08:00
protected override DrawableHitObject<TaikoHitObject, TaikoJudgement> GetVisualRepresentation(TaikoHitObject h)
{
2017-04-03 13:22:22 +08:00
var centreHit = h as CentreHit;
if (centreHit != null)
{
if (h.IsStrong)
return new DrawableStrongCentreHit(centreHit);
return new DrawableCentreHit(centreHit);
}
2016-09-02 18:50:22 +08:00
2017-04-03 13:22:22 +08:00
var rimHit = h as RimHit;
2017-04-03 13:28:28 +08:00
if (rimHit != null)
{
2017-04-03 13:22:22 +08:00
if (h.IsStrong)
return new DrawableStrongRimHit(rimHit);
return new DrawableRimHit(rimHit);
}
var drumRoll = h as DrumRoll;
if (drumRoll != null)
{
if (h.IsStrong)
return new DrawableStrongDrumRoll(drumRoll);
return new DrawableDrumRoll(drumRoll);
}
var swell = h as Swell;
if (swell != null)
return new DrawableSwell(swell);
return null;
}
2017-03-31 15:20:31 +08:00
protected override FramedReplayInputHandler CreateReplayInputHandler(Replay replay) => new TaikoFramedReplayInputHandler(replay);
2016-09-02 18:50:22 +08:00
}
}