mirror of https://github.com/ppy/osu
Merge branch 'master' into master
This commit is contained in:
commit
fc7f9cbae2
|
@ -187,12 +187,12 @@ public void SelectNextRandom()
|
|||
if (groups.Count == 0)
|
||||
return;
|
||||
|
||||
randomSelectedBeatmaps.Push(new KeyValuePair<BeatmapGroup, BeatmapPanel>(selectedGroup, selectedGroup.SelectedPanel));
|
||||
|
||||
var visibleGroups = getVisibleGroups();
|
||||
if (!visibleGroups.Any())
|
||||
return;
|
||||
|
||||
randomSelectedBeatmaps.Push(new KeyValuePair<BeatmapGroup, BeatmapPanel>(selectedGroup, selectedGroup.SelectedPanel));
|
||||
|
||||
BeatmapGroup group;
|
||||
|
||||
if (randomType == SelectionRandomType.RandomPermutation)
|
||||
|
@ -287,6 +287,12 @@ public void Filter(FilterCriteria newCriteria = null, bool debounce = true)
|
|||
perform();
|
||||
}
|
||||
|
||||
public void ScrollToSelected(bool animated = true)
|
||||
{
|
||||
float selectedY = computeYPositions(animated);
|
||||
ScrollTo(selectedY, animated);
|
||||
}
|
||||
|
||||
private BeatmapGroup createGroup(BeatmapSetInfo beatmapSet)
|
||||
{
|
||||
foreach (var b in beatmapSet.Beatmaps)
|
||||
|
@ -426,8 +432,7 @@ private void selectGroup(BeatmapGroup group, BeatmapPanel panel = null, bool ani
|
|||
}
|
||||
finally
|
||||
{
|
||||
float selectedY = computeYPositions(animated);
|
||||
ScrollTo(selectedY, animated);
|
||||
ScrollToSelected(animated);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -129,6 +129,11 @@ protected SongSelect()
|
|||
Right = left_area_padding,
|
||||
},
|
||||
});
|
||||
Add(new ResetScrollContainer(() => carousel.ScrollToSelected())
|
||||
{
|
||||
RelativeSizeAxes = Axes.Y,
|
||||
Width = 250,
|
||||
});
|
||||
|
||||
if (ShowFooter)
|
||||
{
|
||||
|
@ -414,5 +419,21 @@ protected override bool OnKeyDown(InputState state, KeyDownEventArgs args)
|
|||
|
||||
return base.OnKeyDown(state, args);
|
||||
}
|
||||
|
||||
private class ResetScrollContainer : Container
|
||||
{
|
||||
private readonly Action onHoverAction;
|
||||
|
||||
public ResetScrollContainer(Action onHoverAction)
|
||||
{
|
||||
this.onHoverAction = onHoverAction;
|
||||
}
|
||||
|
||||
protected override bool OnHover(InputState state)
|
||||
{
|
||||
onHoverAction?.Invoke();
|
||||
return base.OnHover(state);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue