mirror of
https://github.com/ppy/osu.git
synced 2024-12-15 00:43:21 +08:00
Ensure correct beatmap and ruleset when presenting a score from song select
This commit is contained in:
parent
02b9f51bdd
commit
06f58dd3e3
@ -7,6 +7,7 @@ using osu.Framework.Graphics.Sprites;
|
|||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
using osu.Framework.Screens;
|
using osu.Framework.Screens;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
|
using osu.Game.Scoring;
|
||||||
using osu.Game.Screens.Play;
|
using osu.Game.Screens.Play;
|
||||||
using osu.Game.Screens.Ranking;
|
using osu.Game.Screens.Ranking;
|
||||||
using osu.Game.Users;
|
using osu.Game.Users;
|
||||||
@ -32,9 +33,12 @@ namespace osu.Game.Screens.Select
|
|||||||
Edit();
|
Edit();
|
||||||
}, Key.Number4);
|
}, Key.Number4);
|
||||||
|
|
||||||
((PlayBeatmapDetailArea)BeatmapDetails).Leaderboard.ScoreSelected += score => this.Push(new ResultsScreen(score));
|
((PlayBeatmapDetailArea)BeatmapDetails).Leaderboard.ScoreSelected += PresentScore;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void PresentScore(ScoreInfo score) =>
|
||||||
|
FinaliseSelection(score.Beatmap, score.Ruleset, () => this.Push(new ResultsScreen(score)));
|
||||||
|
|
||||||
protected override BeatmapDetailArea CreateBeatmapDetailArea() => new PlayBeatmapDetailArea();
|
protected override BeatmapDetailArea CreateBeatmapDetailArea() => new PlayBeatmapDetailArea();
|
||||||
|
|
||||||
public override void OnResuming(IScreen last)
|
public override void OnResuming(IScreen last)
|
||||||
|
@ -342,13 +342,17 @@ namespace osu.Game.Screens.Select
|
|||||||
/// Call to make a selection and perform the default action for this SongSelect.
|
/// Call to make a selection and perform the default action for this SongSelect.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="beatmap">An optional beatmap to override the current carousel selection.</param>
|
/// <param name="beatmap">An optional beatmap to override the current carousel selection.</param>
|
||||||
/// <param name="performStartAction">Whether to trigger <see cref="OnStart"/>.</param>
|
/// <param name="ruleset">An optional ruleset to override the current carousel selection.</param>
|
||||||
public void FinaliseSelection(BeatmapInfo beatmap = null, bool performStartAction = true)
|
/// <param name="customStartAction">An optional custom action to perform instead of <see cref="OnStart"/>.</param>
|
||||||
|
public void FinaliseSelection(BeatmapInfo beatmap = null, RulesetInfo ruleset = null, Action customStartAction = null)
|
||||||
{
|
{
|
||||||
// This is very important as we have not yet bound to screen-level bindables before the carousel load is completed.
|
// This is very important as we have not yet bound to screen-level bindables before the carousel load is completed.
|
||||||
if (!Carousel.BeatmapSetsLoaded)
|
if (!Carousel.BeatmapSetsLoaded)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (ruleset != null)
|
||||||
|
Ruleset.Value = ruleset;
|
||||||
|
|
||||||
transferRulesetValue();
|
transferRulesetValue();
|
||||||
|
|
||||||
// while transferRulesetValue will flush, it only does so if the ruleset changes.
|
// while transferRulesetValue will flush, it only does so if the ruleset changes.
|
||||||
@ -369,7 +373,12 @@ namespace osu.Game.Screens.Select
|
|||||||
selectionChangedDebounce = null;
|
selectionChangedDebounce = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (performStartAction && OnStart())
|
if (customStartAction != null)
|
||||||
|
{
|
||||||
|
customStartAction();
|
||||||
|
Carousel.AllowSelection = false;
|
||||||
|
}
|
||||||
|
else if (OnStart())
|
||||||
Carousel.AllowSelection = false;
|
Carousel.AllowSelection = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user