// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence. // See the LICENCE file in the repository root for full licence text. using osu.Game.Database; namespace osu.Game.Beatmaps { public class BeatmapDifficulty : IHasPrimaryKey { /// /// The default value used for all difficulty settings except and . /// public const float DEFAULT_DIFFICULTY = 5; public int ID { get; set; } public float DrainRate { get; set; } = DEFAULT_DIFFICULTY; public float CircleSize { get; set; } = DEFAULT_DIFFICULTY; public float OverallDifficulty { get; set; } = DEFAULT_DIFFICULTY; private float? approachRate; public float ApproachRate { get => approachRate ?? OverallDifficulty; set => approachRate = value; } public double SliderMultiplier { get; set; } = 1; // AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA this needs to be renamed or removed or something. public double SliderTickRate { get; set; } = 1; /// /// Returns a shallow-clone of this . /// public BeatmapDifficulty Clone() { var diff = new BeatmapDifficulty(); CopyTo(diff); return diff; } public void CopyTo(BeatmapDifficulty difficulty) { difficulty.ApproachRate = ApproachRate; difficulty.DrainRate = DrainRate; difficulty.CircleSize = CircleSize; difficulty.OverallDifficulty = OverallDifficulty; difficulty.SliderMultiplier = SliderMultiplier; difficulty.SliderTickRate = SliderTickRate; } /// /// Maps a difficulty value [0, 10] to a two-piece linear range of values. /// /// The difficulty value to be mapped. /// Minimum of the resulting range which will be achieved by a difficulty value of 0. /// Midpoint of the resulting range which will be achieved by a difficulty value of 5. /// Maximum of the resulting range which will be achieved by a difficulty value of 10. /// Value to which the difficulty value maps in the specified range. public static double DifficultyRange(double difficulty, double min, double mid, double max) { if (difficulty > 5) return mid + (max - mid) * (difficulty - 5) / 5; if (difficulty < 5) return mid - (mid - min) * (5 - difficulty) / 5; return mid; } /// /// Maps a difficulty value [0, 10] to a two-piece linear range of values. /// /// The difficulty value to be mapped. /// The values that define the two linear ranges. /// /// /// od0 /// Minimum of the resulting range which will be achieved by a difficulty value of 0. /// /// /// od5 /// Midpoint of the resulting range which will be achieved by a difficulty value of 5. /// /// /// od10 /// Maximum of the resulting range which will be achieved by a difficulty value of 10. /// /// /// /// Value to which the difficulty value maps in the specified range. public static double DifficultyRange(double difficulty, (double od0, double od5, double od10) range) => DifficultyRange(difficulty, range.od0, range.od5, range.od10); } }