1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 16:12:55 +08:00
osu-lazer/osu.Game.Rulesets.Catch/Beatmaps/CatchBeatmapConverter.cs

78 lines
3.4 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 17:19:50 +08:00
using osu.Game.Beatmaps;
using osu.Game.Rulesets.Catch.Objects;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
2018-04-13 17:19:50 +08:00
using osu.Game.Rulesets.Objects.Types;
using osu.Game.Rulesets.Objects;
2019-11-12 18:16:51 +08:00
using osu.Framework.Extensions.IEnumerableExtensions;
using osu.Game.Beatmaps.Legacy;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Rulesets.Catch.Beatmaps
{
public class CatchBeatmapConverter : BeatmapConverter<CatchHitObject>
{
public CatchBeatmapConverter(IBeatmap beatmap, Ruleset ruleset)
: base(beatmap, ruleset)
{
}
2018-05-07 10:23:29 +08:00
public override bool CanConvert() => Beatmap.HitObjects.All(h => h is IHasXPosition);
2018-04-13 17:19:50 +08:00
protected override IEnumerable<CatchHitObject> ConvertHitObject(HitObject obj, IBeatmap beatmap, CancellationToken cancellationToken)
2018-04-13 17:19:50 +08:00
{
var xPositionData = obj as IHasXPosition;
var yPositionData = obj as IHasYPosition;
2018-04-13 17:19:50 +08:00
var comboData = obj as IHasCombo;
var sliderVelocityData = obj as IHasSliderVelocity;
2018-04-13 17:19:50 +08:00
2019-11-12 18:16:51 +08:00
switch (obj)
2018-04-13 17:19:50 +08:00
{
case IHasPathWithRepeats curveData:
2019-11-12 18:16:51 +08:00
return new JuiceStream
{
StartTime = obj.StartTime,
Samples = obj.Samples,
Path = curveData.Path,
NodeSamples = curveData.NodeSamples,
RepeatCount = curveData.RepeatCount,
X = xPositionData?.X ?? 0,
2019-11-12 18:16:51 +08:00
NewCombo = comboData?.NewCombo ?? false,
ComboOffset = comboData?.ComboOffset ?? 0,
LegacyConvertedY = yPositionData?.Y ?? CatchHitObject.DEFAULT_LEGACY_CONVERT_Y,
// prior to v8, speed multipliers don't adjust for how many ticks are generated over the same distance.
// this results in more (or less) ticks being generated in <v8 maps for the same time duration.
2023-12-11 13:39:50 +08:00
TickDistanceMultiplier = beatmap.BeatmapInfo.BeatmapVersion < 8 ? 1f / ((LegacyControlPointInfo)beatmap.ControlPointInfo).DifficultyPointAt(obj.StartTime).SliderVelocity : 1,
SliderVelocityMultiplier = sliderVelocityData?.SliderVelocityMultiplier ?? 1
2019-11-12 18:16:51 +08:00
}.Yield();
2020-05-27 11:38:39 +08:00
case IHasDuration endTime:
2019-11-12 18:16:51 +08:00
return new BananaShower
{
StartTime = obj.StartTime,
Samples = obj.Samples,
Duration = endTime.Duration,
NewCombo = comboData?.NewCombo ?? false,
ComboOffset = comboData?.ComboOffset ?? 0,
}.Yield();
default:
return new Fruit
{
StartTime = obj.StartTime,
Samples = obj.Samples,
NewCombo = comboData?.NewCombo ?? false,
ComboOffset = comboData?.ComboOffset ?? 0,
X = xPositionData?.X ?? 0,
LegacyConvertedY = yPositionData?.Y ?? CatchHitObject.DEFAULT_LEGACY_CONVERT_Y
2019-11-12 18:16:51 +08:00
}.Yield();
}
2018-04-13 17:19:50 +08:00
}
2018-05-07 10:01:09 +08:00
protected override Beatmap<CatchHitObject> CreateBeatmap() => new CatchBeatmap();
2018-04-13 17:19:50 +08:00
}
}