mirror of
https://github.com/ppy/osu
synced 2025-01-10 16:19:47 +00:00
Better choose new selection when multiple items are removed including current
This commit is contained in:
parent
59dbca2612
commit
bd9056c709
@ -257,9 +257,15 @@ namespace osu.Game.Tests.Visual
|
|||||||
private void testRemoveAll()
|
private void testRemoveAll()
|
||||||
{
|
{
|
||||||
setSelected(2, 1);
|
setSelected(2, 1);
|
||||||
|
|
||||||
AddAssert("Selection is non-null", () => currentSelection != null);
|
AddAssert("Selection is non-null", () => currentSelection != null);
|
||||||
|
|
||||||
|
AddStep("Remove selected", () => carousel.RemoveBeatmapSet(carousel.SelectedBeatmapSet));
|
||||||
|
checkSelected(2);
|
||||||
|
|
||||||
|
AddStep("Remove first", () => carousel.RemoveBeatmapSet(carousel.BeatmapSets.First()));
|
||||||
|
AddStep("Remove first", () => carousel.RemoveBeatmapSet(carousel.BeatmapSets.First()));
|
||||||
|
checkSelected(1);
|
||||||
|
|
||||||
AddUntilStep(() =>
|
AddUntilStep(() =>
|
||||||
{
|
{
|
||||||
carousel.RemoveBeatmapSet(carousel.BeatmapSets.Last());
|
carousel.RemoveBeatmapSet(carousel.BeatmapSets.Last());
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
namespace osu.Game.Screens.Select.Carousel
|
namespace osu.Game.Screens.Select.Carousel
|
||||||
@ -19,14 +20,33 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <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 int lastSelectedIndex;
|
||||||
|
|
||||||
|
private CarouselItem lastSelected;
|
||||||
|
|
||||||
public override void Filter(FilterCriteria criteria)
|
public override void Filter(FilterCriteria criteria)
|
||||||
{
|
{
|
||||||
base.Filter(criteria);
|
base.Filter(criteria);
|
||||||
attemptSelection();
|
attemptSelection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void RemoveChild(CarouselItem i)
|
||||||
|
{
|
||||||
|
base.RemoveChild(i);
|
||||||
|
|
||||||
|
if (i != lastSelected)
|
||||||
|
updateSelectedIndex();
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void AddChild(CarouselItem i)
|
||||||
|
{
|
||||||
|
base.AddChild(i);
|
||||||
|
updateSelectedIndex();
|
||||||
|
}
|
||||||
|
|
||||||
protected override void ChildItemStateChanged(CarouselItem item, CarouselItemState value)
|
protected override void ChildItemStateChanged(CarouselItem item, CarouselItemState value)
|
||||||
{
|
{
|
||||||
base.ChildItemStateChanged(item, value);
|
base.ChildItemStateChanged(item, value);
|
||||||
@ -34,7 +54,7 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
switch (value)
|
switch (value)
|
||||||
{
|
{
|
||||||
case CarouselItemState.Selected:
|
case CarouselItemState.Selected:
|
||||||
lastSelectedIndex = InternalChildren.IndexOf(item);
|
updateSelected(item);
|
||||||
break;
|
break;
|
||||||
case CarouselItemState.NotSelected:
|
case CarouselItemState.NotSelected:
|
||||||
attemptSelection();
|
attemptSelection();
|
||||||
@ -56,6 +76,16 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
|
|
||||||
if (nextToSelect != null)
|
if (nextToSelect != null)
|
||||||
nextToSelect.State.Value = CarouselItemState.Selected;
|
nextToSelect.State.Value = CarouselItemState.Selected;
|
||||||
|
else
|
||||||
|
updateSelected(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateSelected(CarouselItem newSelection)
|
||||||
|
{
|
||||||
|
lastSelected = newSelection;
|
||||||
|
updateSelectedIndex();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateSelectedIndex() => lastSelectedIndex = Math.Max(0, InternalChildren.IndexOf(lastSelected));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user