mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 18:12:56 +08:00
Extract random selection logic into CarouselRoot
This commit is contained in:
parent
7e30375443
commit
82a847b820
@ -66,7 +66,7 @@ namespace osu.Game.Screens.Select
|
||||
get { return beatmapSets.Select(g => g.BeatmapSet); }
|
||||
set
|
||||
{
|
||||
CarouselGroup newRoot = new CarouselGroupEagerSelect(this);
|
||||
CarouselRoot newRoot = new CarouselRoot(this);
|
||||
|
||||
Task.Run(() =>
|
||||
{
|
||||
@ -102,11 +102,11 @@ namespace osu.Game.Screens.Select
|
||||
private readonly Stack<CarouselBeatmap> randomSelectedBeatmaps = new Stack<CarouselBeatmap>();
|
||||
|
||||
protected List<DrawableCarouselItem> Items = new List<DrawableCarouselItem>();
|
||||
private CarouselGroup root;
|
||||
private CarouselRoot root;
|
||||
|
||||
public BeatmapCarousel()
|
||||
{
|
||||
root = new CarouselGroupEagerSelect(this);
|
||||
root = new CarouselRoot(this);
|
||||
Child = new OsuContextMenuContainer
|
||||
{
|
||||
RelativeSizeAxes = Axes.X,
|
||||
|
@ -11,11 +11,8 @@ namespace osu.Game.Screens.Select.Carousel
|
||||
/// </summary>
|
||||
public class CarouselGroupEagerSelect : CarouselGroup
|
||||
{
|
||||
private readonly BeatmapCarousel parent;
|
||||
|
||||
public CarouselGroupEagerSelect(BeatmapCarousel parent = null)
|
||||
public CarouselGroupEagerSelect()
|
||||
{
|
||||
this.parent = parent;
|
||||
State.ValueChanged += v =>
|
||||
{
|
||||
if (v == CarouselItemState.Selected)
|
||||
@ -23,13 +20,16 @@ namespace osu.Game.Screens.Select.Carousel
|
||||
};
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// The last selected item.
|
||||
/// </summary>
|
||||
protected CarouselItem LastSelected { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// We need to keep track of the index for cases where the selection is removed but we want to select a new item based on its old location.
|
||||
/// </summary>
|
||||
private int lastSelectedIndex;
|
||||
|
||||
private CarouselItem lastSelected;
|
||||
|
||||
/// <summary>
|
||||
/// To avoid overhead during filter operations, we don't attempt any selections until after all
|
||||
/// children have been filtered. This bool will be true during the base <see cref="Filter(FilterCriteria)"/>
|
||||
@ -50,7 +50,7 @@ namespace osu.Game.Screens.Select.Carousel
|
||||
{
|
||||
base.RemoveChild(i);
|
||||
|
||||
if (i != lastSelected)
|
||||
if (i != LastSelected)
|
||||
updateSelectedIndex();
|
||||
}
|
||||
|
||||
@ -86,12 +86,11 @@ namespace osu.Game.Screens.Select.Carousel
|
||||
// we only perform eager selection if none of our children are in a selected state already.
|
||||
if (Children.Any(i => i.State == CarouselItemState.Selected)) return;
|
||||
|
||||
if (parent != null && lastSelected == null)
|
||||
{
|
||||
parent.SelectNextRandom();
|
||||
return;
|
||||
PerformSelection();
|
||||
}
|
||||
|
||||
protected virtual void PerformSelection()
|
||||
{
|
||||
CarouselItem nextToSelect =
|
||||
Children.Skip(lastSelectedIndex).FirstOrDefault(i => !i.Filtered) ??
|
||||
Children.Reverse().Skip(InternalChildren.Count - lastSelectedIndex).FirstOrDefault(i => !i.Filtered);
|
||||
@ -104,10 +103,10 @@ namespace osu.Game.Screens.Select.Carousel
|
||||
|
||||
private void updateSelected(CarouselItem newSelection)
|
||||
{
|
||||
lastSelected = newSelection;
|
||||
LastSelected = newSelection;
|
||||
updateSelectedIndex();
|
||||
}
|
||||
|
||||
private void updateSelectedIndex() => lastSelectedIndex = lastSelected == null ? 0 : Math.Max(0, InternalChildren.IndexOf(lastSelected));
|
||||
private void updateSelectedIndex() => lastSelectedIndex = LastSelected == null ? 0 : Math.Max(0, InternalChildren.IndexOf(LastSelected));
|
||||
}
|
||||
}
|
||||
|
23
osu.Game/Screens/Select/Carousel/CarouselRoot.cs
Normal file
23
osu.Game/Screens/Select/Carousel/CarouselRoot.cs
Normal file
@ -0,0 +1,23 @@
|
||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||
|
||||
namespace osu.Game.Screens.Select.Carousel
|
||||
{
|
||||
public class CarouselRoot : CarouselGroupEagerSelect
|
||||
{
|
||||
private readonly BeatmapCarousel carousel;
|
||||
|
||||
public CarouselRoot(BeatmapCarousel carousel)
|
||||
{
|
||||
this.carousel = carousel;
|
||||
}
|
||||
|
||||
protected override void PerformSelection()
|
||||
{
|
||||
if (LastSelected == null)
|
||||
carousel.SelectNextRandom();
|
||||
else
|
||||
base.PerformSelection();
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user