1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-10 15:32:56 +08:00
osu-lazer/osu.Game.Rulesets.Catch/CatchRuleset.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

281 lines
10 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 System;
using System.Collections.Generic;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Input.Bindings;
using osu.Framework.Localisation;
using osu.Game.Beatmaps;
2018-04-13 21:41:35 +08:00
using osu.Game.Beatmaps.Legacy;
using osu.Game.Graphics;
using osu.Game.Rulesets.Catch.Beatmaps;
using osu.Game.Rulesets.Catch.Difficulty;
using osu.Game.Rulesets.Catch.Edit;
using osu.Game.Rulesets.Catch.Mods;
using osu.Game.Rulesets.Catch.Objects;
using osu.Game.Rulesets.Catch.Replays;
using osu.Game.Rulesets.Catch.Scoring;
using osu.Game.Rulesets.Catch.Skinning.Argon;
using osu.Game.Rulesets.Catch.Skinning.Legacy;
using osu.Game.Rulesets.Catch.UI;
using osu.Game.Rulesets.Difficulty;
using osu.Game.Rulesets.Edit;
using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.Replays.Types;
using osu.Game.Rulesets.Scoring;
using osu.Game.Rulesets.Scoring.Legacy;
using osu.Game.Rulesets.UI;
using osu.Game.Scoring;
using osu.Game.Screens.Edit.Setup;
using osu.Game.Screens.Ranking.Statistics;
using osu.Game.Skinning;
using osuTK;
2018-04-13 17:19:50 +08:00
2017-04-18 15:05:58 +08:00
namespace osu.Game.Rulesets.Catch
{
2019-12-24 12:48:27 +08:00
public class CatchRuleset : Ruleset, ILegacyRuleset
{
public override DrawableRuleset CreateDrawableRulesetWith(IBeatmap beatmap, IReadOnlyList<Mod>? mods = null) => new DrawableCatchRuleset(this, beatmap, mods);
2019-12-17 19:08:13 +08:00
public override ScoreProcessor CreateScoreProcessor() => new CatchScoreProcessor();
2019-12-17 19:08:13 +08:00
public override HealthProcessor CreateHealthProcessor(double drainStartTime) => new CatchHealthProcessor(drainStartTime);
public override IBeatmapConverter CreateBeatmapConverter(IBeatmap beatmap) => new CatchBeatmapConverter(beatmap, this);
public override IBeatmapProcessor CreateBeatmapProcessor(IBeatmap beatmap) => new CatchBeatmapProcessor(beatmap);
2018-04-13 17:19:50 +08:00
2019-09-02 13:41:14 +08:00
public const string SHORT_NAME = "fruits";
public override string RulesetAPIVersionSupported => CURRENT_RULESET_API_VERSION;
2022-08-22 15:10:55 +08:00
public override IEnumerable<KeyBinding> GetDefaultKeyBindings(int variant = 0) => new[]
{
new KeyBinding(InputKey.Z, CatchAction.MoveLeft),
new KeyBinding(InputKey.Left, CatchAction.MoveLeft),
new KeyBinding(InputKey.X, CatchAction.MoveRight),
new KeyBinding(InputKey.Right, CatchAction.MoveRight),
new KeyBinding(InputKey.Shift, CatchAction.Dash),
new KeyBinding(InputKey.MouseLeft, CatchAction.Dash),
};
2018-04-13 17:19:50 +08:00
public override IEnumerable<Mod> ConvertFromLegacyMods(LegacyMods mods)
2018-04-13 21:41:35 +08:00
{
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Nightcore))
2018-04-13 21:41:35 +08:00
yield return new CatchModNightcore();
2024-07-02 23:19:04 +08:00
else if (mods.HasFlag(LegacyMods.DoubleTime))
2018-04-13 21:41:35 +08:00
yield return new CatchModDoubleTime();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Perfect))
yield return new CatchModPerfect();
2024-07-02 23:19:04 +08:00
else if (mods.HasFlag(LegacyMods.SuddenDeath))
yield return new CatchModSuddenDeath();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Cinema))
2019-11-24 01:32:16 +08:00
yield return new CatchModCinema();
2024-07-02 23:19:04 +08:00
else if (mods.HasFlag(LegacyMods.Autoplay))
2018-04-13 21:41:35 +08:00
yield return new CatchModAutoplay();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Easy))
2018-04-13 21:41:35 +08:00
yield return new CatchModEasy();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Flashlight))
2018-04-13 21:41:35 +08:00
yield return new CatchModFlashlight();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.HalfTime))
2018-04-13 21:41:35 +08:00
yield return new CatchModHalfTime();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.HardRock))
2018-04-13 21:41:35 +08:00
yield return new CatchModHardRock();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Hidden))
2018-04-13 21:41:35 +08:00
yield return new CatchModHidden();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.NoFail))
2018-04-13 21:41:35 +08:00
yield return new CatchModNoFail();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.Relax))
2018-04-13 21:41:35 +08:00
yield return new CatchModRelax();
2024-07-02 23:19:04 +08:00
if (mods.HasFlag(LegacyMods.ScoreV2))
yield return new ModScoreV2();
2018-04-13 21:41:35 +08:00
}
public override IEnumerable<Mod> GetModsFor(ModType type)
{
switch (type)
{
case ModType.DifficultyReduction:
return new Mod[]
{
new CatchModEasy(),
new CatchModNoFail(),
2018-06-06 13:07:50 +08:00
new MultiMod(new CatchModHalfTime(), new CatchModDaycore())
};
2019-04-01 11:44:46 +08:00
case ModType.DifficultyIncrease:
return new Mod[]
{
new CatchModHardRock(),
2018-06-06 13:07:50 +08:00
new MultiMod(new CatchModSuddenDeath(), new CatchModPerfect()),
new MultiMod(new CatchModDoubleTime(), new CatchModNightcore()),
new CatchModHidden(),
new CatchModFlashlight(),
2022-05-24 22:56:31 +08:00
new ModAccuracyChallenge(),
};
2019-04-01 11:44:46 +08:00
2019-12-11 19:43:16 +08:00
case ModType.Conversion:
return new Mod[]
{
2019-12-20 18:30:23 +08:00
new CatchModDifficultyAdjust(),
new CatchModClassic(),
2021-08-09 01:45:13 +08:00
new CatchModMirror(),
2019-12-11 19:43:16 +08:00
};
case ModType.Automation:
return new Mod[]
{
2019-11-24 01:32:16 +08:00
new MultiMod(new CatchModAutoplay(), new CatchModCinema()),
new CatchModRelax(),
};
2019-04-01 11:44:46 +08:00
2019-01-26 12:15:45 +08:00
case ModType.Fun:
return new Mod[]
{
2021-04-17 22:01:23 +08:00
new MultiMod(new ModWindUp(), new ModWindDown()),
2021-07-28 18:21:08 +08:00
new CatchModFloatingFruits(),
new CatchModMuted(),
new CatchModNoScope(),
2019-01-26 12:15:45 +08:00
};
2019-04-01 11:44:46 +08:00
case ModType.System:
return new Mod[]
{
new ModScoreV2(),
};
default:
2019-11-28 21:41:29 +08:00
return Array.Empty<Mod>();
}
}
2018-04-13 17:19:50 +08:00
public override string Description => "osu!catch";
2018-04-13 17:19:50 +08:00
public override string ShortName => SHORT_NAME;
2018-04-13 17:19:50 +08:00
public override string PlayingVerb => "Catching fruit";
public override Drawable CreateIcon() => new SpriteIcon { Icon = OsuIcon.RulesetCatch };
2018-04-13 17:19:50 +08:00
protected override IEnumerable<HitResult> GetValidHitResults()
{
return new[]
{
HitResult.Great,
HitResult.LargeTickHit,
HitResult.SmallTickHit,
HitResult.LargeBonus,
};
}
2022-08-15 02:54:02 +08:00
public override LocalisableString GetDisplayNameForHitResult(HitResult result)
{
switch (result)
{
case HitResult.LargeTickHit:
return "Large droplet";
case HitResult.SmallTickHit:
return "Small droplet";
case HitResult.LargeBonus:
return "Banana";
}
return base.GetDisplayNameForHitResult(result);
}
public override DifficultyCalculator CreateDifficultyCalculator(IWorkingBeatmap beatmap) => new CatchDifficultyCalculator(RulesetInfo, beatmap);
2018-04-13 17:19:50 +08:00
public override ISkin? CreateSkinTransformer(ISkin skin, IBeatmap beatmap)
{
switch (skin)
{
case LegacySkin:
return new CatchLegacySkinTransformer(skin);
case ArgonSkin:
return new CatchArgonSkinTransformer(skin);
}
return null;
}
2022-03-15 11:37:39 +08:00
public override PerformanceCalculator CreatePerformanceCalculator() => new CatchPerformanceCalculator();
2019-12-24 12:48:27 +08:00
public int LegacyID => 2;
2018-04-13 17:19:50 +08:00
public ILegacyScoreSimulator CreateLegacyScoreSimulator() => new CatchLegacyScoreSimulator();
public override IConvertibleReplayFrame CreateConvertibleReplayFrame() => new CatchReplayFrame();
2021-06-22 09:05:29 +08:00
public override HitObjectComposer CreateHitObjectComposer() => new CatchHitObjectComposer(this);
public override IEnumerable<Drawable> CreateEditorSetupSections() =>
[
new MetadataSection(),
new DifficultySection(),
new FillFlowContainer
{
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Spacing = new Vector2(SetupScreen.SPACING),
Children = new Drawable[]
{
new ResourcesSection
{
RelativeSizeAxes = Axes.X,
},
new ColoursSection
{
RelativeSizeAxes = Axes.X,
}
}
},
new DesignSection(),
];
public override IBeatmapVerifier CreateBeatmapVerifier() => new CatchBeatmapVerifier();
public override StatisticItem[] CreateStatisticsForScore(ScoreInfo score, IBeatmap playableBeatmap)
{
return new[]
{
new StatisticItem("Performance Breakdown", () => new PerformanceBreakdownChart(score, playableBeatmap)
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y
}),
};
}
/// <seealso cref="CatchHitObject.ApplyDefaultsToSelf"/>
public override BeatmapDifficulty GetRateAdjustedDisplayDifficulty(IBeatmapDifficultyInfo difficulty, double rate)
{
BeatmapDifficulty adjustedDifficulty = new BeatmapDifficulty(difficulty);
double preempt = IBeatmapDifficultyInfo.DifficultyRange(adjustedDifficulty.ApproachRate, CatchHitObject.PREEMPT_MAX, CatchHitObject.PREEMPT_MID, CatchHitObject.PREEMPT_MIN);
2023-11-10 00:23:53 +08:00
preempt /= rate;
adjustedDifficulty.ApproachRate = (float)IBeatmapDifficultyInfo.InverseDifficultyRange(preempt, CatchHitObject.PREEMPT_MAX, CatchHitObject.PREEMPT_MID, CatchHitObject.PREEMPT_MIN);
2023-11-12 15:20:13 +08:00
return adjustedDifficulty;
}
public override bool EditorShowScrollSpeed => false;
}
}