mirror of
https://github.com/ppy/osu.git
synced 2025-01-30 07:32:55 +08:00
Allow grouped difficulty icons to be clicked
This commit is contained in:
parent
db5c8043db
commit
6e11c3014c
@ -654,6 +654,48 @@ namespace osu.Game.Tests.Visual.SongSelect
|
|||||||
AddUntilStep("Check ruleset changed to mania", () => Ruleset.Value.ID == 3);
|
AddUntilStep("Check ruleset changed to mania", () => Ruleset.Value.ID == 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestGroupedDifficultyIconSelecting()
|
||||||
|
{
|
||||||
|
changeRuleset(0);
|
||||||
|
|
||||||
|
createSongSelect();
|
||||||
|
|
||||||
|
AddStep("import huge difficulty count map", () =>
|
||||||
|
{
|
||||||
|
var usableRulesets = rulesets.AvailableRulesets.Where(r => r.ID != 2).ToArray();
|
||||||
|
manager.Import(createTestBeatmapSet(0, usableRulesets, 50)).Wait();
|
||||||
|
});
|
||||||
|
|
||||||
|
DrawableCarouselBeatmapSet set = null;
|
||||||
|
AddUntilStep("Find the DrawableCarouselBeatmapSet", () =>
|
||||||
|
{
|
||||||
|
set = songSelect.Carousel.ChildrenOfType<DrawableCarouselBeatmapSet>().FirstOrDefault();
|
||||||
|
return set != null;
|
||||||
|
});
|
||||||
|
|
||||||
|
DrawableCarouselBeatmapSet.FilterableGroupedDifficultyIcon groupIcon = null;
|
||||||
|
AddStep("Find group icon for different ruleset", () =>
|
||||||
|
{
|
||||||
|
groupIcon = set.ChildrenOfType<DrawableCarouselBeatmapSet.FilterableGroupedDifficultyIcon>()
|
||||||
|
.First(icon => icon.Items.First().Beatmap.Ruleset.ID == 3);
|
||||||
|
});
|
||||||
|
|
||||||
|
AddAssert("Check ruleset is osu!", () => Ruleset.Value.ID == 0);
|
||||||
|
|
||||||
|
AddStep("Click on group", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(groupIcon);
|
||||||
|
|
||||||
|
InputManager.PressButton(MouseButton.Left);
|
||||||
|
InputManager.ReleaseButton(MouseButton.Left);
|
||||||
|
});
|
||||||
|
|
||||||
|
AddUntilStep("Check ruleset changed to mania", () => Ruleset.Value.ID == 3);
|
||||||
|
|
||||||
|
AddAssert("Check first item in group selected", () => Beatmap.Value.BeatmapInfo == groupIcon.Items.First().Beatmap);
|
||||||
|
}
|
||||||
|
|
||||||
private int getBeatmapIndex(BeatmapSetInfo set, BeatmapInfo info) => set.Beatmaps.FindIndex(b => b == info);
|
private int getBeatmapIndex(BeatmapSetInfo set, BeatmapInfo info) => set.Beatmaps.FindIndex(b => b == info);
|
||||||
|
|
||||||
private int getCurrentBeatmapIndex() => getBeatmapIndex(songSelect.Carousel.SelectedBeatmapSet, songSelect.Carousel.SelectedBeatmap);
|
private int getCurrentBeatmapIndex() => getBeatmapIndex(songSelect.Carousel.SelectedBeatmapSet, songSelect.Carousel.SelectedBeatmap);
|
||||||
@ -695,16 +737,16 @@ namespace osu.Game.Tests.Visual.SongSelect
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private BeatmapSetInfo createTestBeatmapSet(int setId, RulesetInfo[] rulesets)
|
private BeatmapSetInfo createTestBeatmapSet(int setId, RulesetInfo[] rulesets, int countPerRuleset = 6)
|
||||||
{
|
{
|
||||||
int j = 0;
|
int j = 0;
|
||||||
RulesetInfo getRuleset() => rulesets[j++ % rulesets.Length];
|
RulesetInfo getRuleset() => rulesets[j++ % rulesets.Length];
|
||||||
|
|
||||||
var beatmaps = new List<BeatmapInfo>();
|
var beatmaps = new List<BeatmapInfo>();
|
||||||
|
|
||||||
for (int i = 0; i < 6; i++)
|
for (int i = 0; i < countPerRuleset; i++)
|
||||||
{
|
{
|
||||||
int beatmapId = setId * 10 + i;
|
int beatmapId = setId * 100 + i;
|
||||||
|
|
||||||
int length = RNG.Next(30000, 200000);
|
int length = RNG.Next(30000, 200000);
|
||||||
double bpm = RNG.NextSingle(80, 200);
|
double bpm = RNG.NextSingle(80, 200);
|
||||||
|
@ -228,12 +228,12 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
|
|
||||||
public class FilterableGroupedDifficultyIcon : GroupedDifficultyIcon
|
public class FilterableGroupedDifficultyIcon : GroupedDifficultyIcon
|
||||||
{
|
{
|
||||||
private readonly List<CarouselBeatmap> items;
|
public readonly List<CarouselBeatmap> Items;
|
||||||
|
|
||||||
public FilterableGroupedDifficultyIcon(List<CarouselBeatmap> items, RulesetInfo ruleset)
|
public FilterableGroupedDifficultyIcon(List<CarouselBeatmap> items, RulesetInfo ruleset)
|
||||||
: base(items.Select(i => i.Beatmap).ToList(), ruleset, Color4.White)
|
: base(items.Select(i => i.Beatmap).ToList(), ruleset, Color4.White)
|
||||||
{
|
{
|
||||||
this.items = items;
|
Items = items;
|
||||||
|
|
||||||
foreach (var item in items)
|
foreach (var item in items)
|
||||||
item.Filtered.BindValueChanged(_ => Scheduler.AddOnce(updateFilteredDisplay));
|
item.Filtered.BindValueChanged(_ => Scheduler.AddOnce(updateFilteredDisplay));
|
||||||
@ -241,10 +241,16 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
updateFilteredDisplay();
|
updateFilteredDisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override bool OnClick(ClickEvent e)
|
||||||
|
{
|
||||||
|
Items.First().State.Value = CarouselItemState.Selected;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
private void updateFilteredDisplay()
|
private void updateFilteredDisplay()
|
||||||
{
|
{
|
||||||
// for now, fade the whole group based on the ratio of hidden items.
|
// for now, fade the whole group based on the ratio of hidden items.
|
||||||
this.FadeTo(1 - 0.9f * ((float)items.Count(i => i.Filtered.Value) / items.Count), 100);
|
this.FadeTo(1 - 0.9f * ((float)Items.Count(i => i.Filtered.Value) / Items.Count), 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user