mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 06:42:54 +08:00
Use PlaylistList to manage Prev/Next tracks
This commit is contained in:
parent
5c3b7ac12c
commit
97ebf38288
@ -29,8 +29,8 @@ namespace osu.Game.Overlays.Music
|
||||
private IEnumerable<SpriteText> titleSprites;
|
||||
private UnicodeBindableString titleBind;
|
||||
private UnicodeBindableString artistBind;
|
||||
private FillFlowContainer<PlaylistItem> Playlist;
|
||||
|
||||
private readonly FillFlowContainer<PlaylistItem> Playlist;
|
||||
public readonly BeatmapSetInfo BeatmapSetInfo;
|
||||
|
||||
public Action<BeatmapSetInfo> OnSelect;
|
||||
|
@ -46,6 +46,24 @@ namespace osu.Game.Overlays.Music
|
||||
}
|
||||
}
|
||||
|
||||
public BeatmapSetInfo NextItem
|
||||
{
|
||||
get
|
||||
{
|
||||
var available = items.Children;
|
||||
return (available.SkipWhile(i => !i.Selected).Skip(1).FirstOrDefault() ?? available.FirstOrDefault())?.BeatmapSetInfo;
|
||||
}
|
||||
}
|
||||
|
||||
public BeatmapSetInfo PreviousItem
|
||||
{
|
||||
get
|
||||
{
|
||||
var available = items.Children.Reverse();
|
||||
return (available.SkipWhile(i => !i.Selected).Skip(1).FirstOrDefault() ?? available.FirstOrDefault())?.BeatmapSetInfo;
|
||||
}
|
||||
}
|
||||
|
||||
public PlaylistList()
|
||||
{
|
||||
Children = new Drawable[]
|
||||
|
@ -126,24 +126,24 @@ namespace osu.Game.Overlays.Music
|
||||
|
||||
public void PlayPrevious()
|
||||
{
|
||||
var currentID = beatmapBacking.Value?.BeatmapSetInfo.ID ?? -1;
|
||||
var available = BeatmapSets.Reverse();
|
||||
|
||||
var playable = available.SkipWhile(b => b.ID != currentID).Skip(1).FirstOrDefault() ?? available.FirstOrDefault();
|
||||
var playable = list.PreviousItem;
|
||||
|
||||
if (playable != null)
|
||||
{
|
||||
playSpecified(playable.Beatmaps[0]);
|
||||
list.SelectedItem = playable;
|
||||
}
|
||||
}
|
||||
|
||||
public void PlayNext()
|
||||
{
|
||||
var currentID = beatmapBacking.Value?.BeatmapSetInfo.ID ?? -1;
|
||||
var available = BeatmapSets;
|
||||
|
||||
var playable = available.SkipWhile(b => b.ID != currentID).Skip(1).FirstOrDefault() ?? available.FirstOrDefault();
|
||||
var playable = list.NextItem;
|
||||
|
||||
if (playable != null)
|
||||
{
|
||||
playSpecified(playable.Beatmaps[0]);
|
||||
list.SelectedItem = playable;
|
||||
}
|
||||
}
|
||||
|
||||
private void playSpecified(BeatmapInfo info)
|
||||
|
Loading…
Reference in New Issue
Block a user