1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-17 16:12:53 +08:00
osu-lazer/osu.Game/Beatmaps/BeatmapInfo.cs

181 lines
5.9 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;
2018-04-13 17:19:50 +08:00
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Newtonsoft.Json;
using osu.Framework.Testing;
2018-04-13 17:19:50 +08:00
using osu.Game.Database;
using osu.Game.Online.API.Requests.Responses;
2018-04-13 17:19:50 +08:00
using osu.Game.Rulesets;
using osu.Game.Scoring;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Beatmaps
{
[ExcludeFromDynamicCompile]
2018-04-13 17:19:50 +08:00
[Serializable]
public class BeatmapInfo : IEquatable<BeatmapInfo>, IHasPrimaryKey, IBeatmapInfo
2018-04-13 17:19:50 +08:00
{
public int ID { get; set; }
public int BeatmapVersion;
private int? onlineID;
2018-04-13 17:19:50 +08:00
[JsonProperty("id")]
[Column("OnlineBeatmapID")]
public int? OnlineID
2018-04-13 17:19:50 +08:00
{
get => onlineID;
set => onlineID = value > 0 ? value : null;
2018-04-13 17:19:50 +08:00
}
2018-11-30 17:06:48 +08:00
[JsonIgnore]
2018-04-13 17:19:50 +08:00
public int BeatmapSetInfoID { get; set; }
public BeatmapOnlineStatus Status { get; set; } = BeatmapOnlineStatus.None;
2018-04-13 17:19:50 +08:00
[Required]
public BeatmapSetInfo BeatmapSet { get; set; }
public BeatmapMetadata Metadata { get; set; }
[JsonIgnore]
public int BaseDifficultyID { get; set; }
public BeatmapDifficulty BaseDifficulty { get; set; }
[NotMapped]
public APIBeatmap OnlineInfo { get; set; }
2018-04-13 17:19:50 +08:00
2020-02-20 00:58:10 +08:00
[NotMapped]
public int? MaxCombo { get; set; }
2019-07-08 01:25:36 +08:00
/// <summary>
2019-07-09 22:31:15 +08:00
/// The playable length in milliseconds of this beatmap.
2019-07-08 01:25:36 +08:00
/// </summary>
public double Length { get; set; }
2019-07-08 15:43:35 +08:00
/// <summary>
/// The most common BPM of this beatmap.
/// </summary>
public double BPM { get; set; }
2018-04-13 17:19:50 +08:00
public string Path { get; set; }
[JsonProperty("file_sha2")]
public string Hash { get; set; }
[JsonIgnore]
public bool Hidden { get; set; }
/// <summary>
/// MD5 is kept for legacy support (matching against replays, osu-web-10 etc.).
/// </summary>
[JsonProperty("file_md5")]
public string MD5Hash { get; set; }
// General
2019-11-21 17:21:49 +08:00
public double AudioLeadIn { get; set; }
public float StackLeniency { get; set; } = 0.7f;
2018-04-13 17:19:50 +08:00
public bool SpecialStyle { get; set; }
public int RulesetID { get; set; }
public RulesetInfo Ruleset { get; set; }
public bool LetterboxInBreaks { get; set; }
public bool WidescreenStoryboard { get; set; }
2020-07-20 18:36:42 +08:00
public bool EpilepsyWarning { get; set; }
/// <summary>
/// Whether or not sound samples should change rate when playing with speed-changing mods.
/// TODO: only read/write supported for now, requires implementation in gameplay.
/// </summary>
public bool SamplesMatchPlaybackRate { get; set; }
public CountdownType Countdown { get; set; } = CountdownType.Normal;
/// <summary>
/// The number of beats to move the countdown backwards (compared to its default location).
/// </summary>
public int CountdownOffset { get; set; }
2018-04-13 17:19:50 +08:00
[NotMapped]
2019-11-28 21:41:29 +08:00
public int[] Bookmarks { get; set; } = Array.Empty<int>();
2018-04-13 17:19:50 +08:00
public double DistanceSpacing { get; set; }
public int BeatDivisor { get; set; }
public int GridSize { get; set; }
public double TimelineZoom { get; set; }
// Metadata
[Column("Version")]
public string DifficultyName { get; set; }
2021-04-18 09:52:25 +08:00
2018-04-13 17:19:50 +08:00
[JsonProperty("difficulty_rating")]
[Column("StarDifficulty")]
public double StarRating { get; set; }
2018-04-13 17:19:50 +08:00
/// <summary>
/// Currently only populated for beatmap deletion. Use <see cref="ScoreManager"/> to query scores.
/// </summary>
public List<ScoreInfo> Scores { get; set; }
[JsonIgnore]
public DifficultyRating DifficultyRating => BeatmapDifficultyCache.GetDifficultyRating(StarRating);
public override string ToString() => this.GetDisplayTitle();
2018-04-13 17:19:50 +08:00
2021-11-12 17:48:34 +08:00
public bool Equals(BeatmapInfo other)
2021-11-12 17:09:45 +08:00
{
2021-11-12 17:48:34 +08:00
if (ReferenceEquals(this, other)) return true;
if (other == null) return false;
2021-11-12 17:09:45 +08:00
2021-11-12 17:48:34 +08:00
if (ID != 0 && other.ID != 0)
return ID == other.ID;
2021-11-12 17:09:45 +08:00
return false;
}
public bool Equals(IBeatmapInfo other) => other is BeatmapInfo b && Equals(b);
2018-04-13 17:19:50 +08:00
public bool AudioEquals(BeatmapInfo other) => other != null && BeatmapSet != null && other.BeatmapSet != null &&
BeatmapSet.Hash == other.BeatmapSet.Hash &&
(Metadata ?? BeatmapSet.Metadata).AudioFile == (other.Metadata ?? other.BeatmapSet.Metadata).AudioFile;
public bool BackgroundEquals(BeatmapInfo other) => other != null && BeatmapSet != null && other.BeatmapSet != null &&
BeatmapSet.Hash == other.BeatmapSet.Hash &&
(Metadata ?? BeatmapSet.Metadata).BackgroundFile == (other.Metadata ?? other.BeatmapSet.Metadata).BackgroundFile;
/// <summary>
/// Returns a shallow-clone of this <see cref="BeatmapInfo"/>.
/// </summary>
public BeatmapInfo Clone() => (BeatmapInfo)MemberwiseClone();
#region Implementation of IHasOnlineID
int IHasOnlineID<int>.OnlineID => OnlineID ?? -1;
#endregion
#region Implementation of IBeatmapInfo
[JsonIgnore]
IBeatmapMetadataInfo IBeatmapInfo.Metadata => Metadata ?? BeatmapSet?.Metadata ?? new BeatmapMetadata();
[JsonIgnore]
IBeatmapDifficultyInfo IBeatmapInfo.Difficulty => BaseDifficulty;
[JsonIgnore]
IBeatmapSetInfo IBeatmapInfo.BeatmapSet => BeatmapSet;
[JsonIgnore]
IRulesetInfo IBeatmapInfo.Ruleset => Ruleset;
#endregion
2018-04-13 17:19:50 +08:00
}
}