1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-15 13:47:24 +08:00
osu-lazer/osu.Game/Screens/Play/GameplayState.cs

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

95 lines
3.2 KiB
C#
Raw Normal View History

2021-10-02 01:22:23 +08:00
// 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.
2021-10-05 13:48:10 +08:00
using System;
2021-10-02 01:22:23 +08:00
using System.Collections.Generic;
using osu.Framework.Bindables;
using osu.Game.Beatmaps;
using osu.Game.Rulesets;
using osu.Game.Rulesets.Judgements;
using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.Scoring;
2021-10-04 19:33:54 +08:00
using osu.Game.Scoring;
using osu.Game.Storyboards;
2021-10-02 01:22:23 +08:00
namespace osu.Game.Screens.Play
{
2021-10-02 01:28:35 +08:00
/// <summary>
/// The state of an active gameplay session, generally constructed and exposed by <see cref="Player"/>.
/// </summary>
2021-10-02 01:22:23 +08:00
public class GameplayState
{
/// <summary>
/// The final post-convert post-mod-application beatmap.
/// </summary>
public readonly IBeatmap Beatmap;
2021-10-02 01:28:35 +08:00
/// <summary>
/// The ruleset used in gameplay.
/// </summary>
2021-10-02 01:22:23 +08:00
public readonly Ruleset Ruleset;
2021-10-02 01:28:35 +08:00
/// <summary>
/// The mods applied to the gameplay.
/// </summary>
2021-10-04 19:20:24 +08:00
public readonly IReadOnlyList<Mod> Mods;
2021-10-02 01:22:23 +08:00
2021-10-04 19:33:54 +08:00
/// <summary>
/// The gameplay score.
/// </summary>
2021-10-05 13:48:10 +08:00
public readonly Score Score;
2021-10-04 19:33:54 +08:00
public readonly ScoreProcessor ScoreProcessor;
/// <summary>
/// The storyboard associated with the beatmap.
/// </summary>
public readonly Storyboard Storyboard;
/// <summary>
/// Whether gameplay completed without the user failing.
/// </summary>
public bool HasPassed { get; set; }
/// <summary>
/// Whether the user failed during gameplay. This is only set when the gameplay session has completed due to the fail.
/// </summary>
public bool HasFailed { get; set; }
2022-01-26 01:02:31 +08:00
/// <summary>
2022-02-08 20:20:33 +08:00
/// Whether the user quit gameplay without having either passed or failed.
2022-01-26 01:02:31 +08:00
/// </summary>
public bool HasQuit { get; set; }
2021-10-02 01:28:35 +08:00
/// <summary>
/// A bindable tracking the last judgement result applied to any hit object.
/// </summary>
public IBindable<JudgementResult> LastJudgementResult => lastJudgementResult;
private readonly Bindable<JudgementResult> lastJudgementResult = new Bindable<JudgementResult>();
public GameplayState(IBeatmap beatmap, Ruleset ruleset, IReadOnlyList<Mod>? mods = null, Score? score = null, ScoreProcessor? scoreProcessor = null, Storyboard? storyboard = null)
2021-10-02 01:22:23 +08:00
{
Beatmap = beatmap;
Ruleset = ruleset;
Score = score ?? new Score
{
ScoreInfo =
{
BeatmapInfo = beatmap.BeatmapInfo,
Ruleset = ruleset.RulesetInfo
}
};
Mods = mods ?? Array.Empty<Mod>();
ScoreProcessor = scoreProcessor ?? ruleset.CreateScoreProcessor();
Storyboard = storyboard ?? new Storyboard();
2021-10-02 01:22:23 +08:00
}
2021-10-02 01:28:35 +08:00
/// <summary>
/// Applies the score change of a <see cref="JudgementResult"/> to this <see cref="GameplayState"/>.
/// </summary>
/// <param name="result">The <see cref="JudgementResult"/> to apply.</param>
2021-10-02 01:22:23 +08:00
public void ApplyResult(JudgementResult result) => lastJudgementResult.Value = result;
}
}