1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-29 02:12:57 +08:00

Reorganise song select methods to allow for more flexibility.

This commit is contained in:
Dean Herbert 2017-03-17 02:08:42 +09:00
parent 847f96de94
commit 9c664e5b05
No known key found for this signature in database
GPG Key ID: 46D71BF4958ABB49

View File

@ -352,24 +352,36 @@ namespace osu.Game.Screens.Select
} }
} }
private void addBeatmapSet(BeatmapSetInfo beatmapSet, Framework.Game game, bool select = false) private BeatmapGroup prepareBeatmapSet(BeatmapSetInfo beatmapSet)
{ {
beatmapSet = database.GetWithChildren<BeatmapSetInfo>(beatmapSet.ID); database.GetChildren(beatmapSet);
beatmapSet.Beatmaps.ForEach(b => beatmapSet.Beatmaps.ForEach(b => { if (b.Metadata == null) b.Metadata = beatmapSet.Metadata; });
{
database.GetChildren(b);
if (b.Metadata == null) b.Metadata = beatmapSet.Metadata;
});
var group = new BeatmapGroup(beatmapSet, database) return new BeatmapGroup(beatmapSet, database)
{ {
SelectionChanged = selectionChanged, SelectionChanged = selectionChanged,
StartRequested = b => raiseSelect() StartRequested = b => raiseSelect()
}; };
}
private void addBeatmapSet(BeatmapSetInfo beatmapSet, Framework.Game game, bool select = false)
{
var group = prepareBeatmapSet(beatmapSet);
//for the time being, let's completely load the difficulty panels in the background. //for the time being, let's completely load the difficulty panels in the background.
//this likely won't scale so well, but allows us to completely async the loading flow. //this likely won't scale so well, but allows us to completely async the loading flow.
Task.WhenAll(group.BeatmapPanels.Select(panel => panel.LoadAsync(game))).ContinueWith(task => Schedule(delegate Task.WhenAll(group.BeatmapPanels.Select(panel => panel.LoadAsync(game))).ContinueWith(task => Schedule(delegate
{
addGroup(group);
if (Beatmap == null || select)
selectBeatmap(beatmapSet);
else
selectBeatmap();
}));
}
private void addGroup(BeatmapGroup group)
{ {
beatmapGroups.Add(group); beatmapGroups.Add(group);
@ -377,12 +389,29 @@ namespace osu.Game.Screens.Select
carousel.AddGroup(group); carousel.AddGroup(group);
filterChanged(false, false); filterChanged(false, false);
}
if (Beatmap == null || select) private void selectBeatmap(BeatmapSetInfo beatmapSet = null)
carousel.SelectBeatmap(beatmapSet.Beatmaps.First()); {
else carousel.SelectBeatmap(beatmapSet != null ? beatmapSet.Beatmaps.First() : Beatmap.BeatmapInfo);
carousel.SelectBeatmap(Beatmap.BeatmapInfo); }
}));
private void addBeatmapSets(Framework.Game game, CancellationToken token)
{
List<BeatmapGroup> groups = new List<BeatmapGroup>();
foreach (var beatmapSet in database.Query<BeatmapSetInfo>().Where(b => !b.DeletePending))
{
if (token.IsCancellationRequested) return;
groups.Add(prepareBeatmapSet(beatmapSet));
}
Schedule(() =>
{
groups.ForEach(addGroup);
selectBeatmap(Beatmap?.BeatmapSetInfo ?? groups.First().BeatmapSet);
});
} }
private void removeBeatmapSet(BeatmapSetInfo beatmapSet) private void removeBeatmapSet(BeatmapSetInfo beatmapSet)
@ -400,15 +429,6 @@ namespace osu.Game.Screens.Select
Beatmap = null; Beatmap = null;
} }
private void addBeatmapSets(Framework.Game game, CancellationToken token)
{
foreach (var beatmapSet in database.Query<BeatmapSetInfo>().Where(b => !b.DeletePending))
{
if (token.IsCancellationRequested) return;
addBeatmapSet(beatmapSet, game);
}
}
private void promptDelete() private void promptDelete()
{ {
if (Beatmap != null) if (Beatmap != null)