mirror of
https://github.com/ppy/osu.git
synced 2025-01-12 15:22:55 +08:00
Merge pull request #26674 from peppy/use-better-enumerator
Reduce enumerator overhead in `GameplayLeaderboard`
This commit is contained in:
commit
871683a3dc
@ -16,15 +16,14 @@
|
|||||||
"osu.Game.Tournament.Tests\\osu.Game.Tournament.Tests.csproj",
|
"osu.Game.Tournament.Tests\\osu.Game.Tournament.Tests.csproj",
|
||||||
"osu.Game.Tournament\\osu.Game.Tournament.csproj",
|
"osu.Game.Tournament\\osu.Game.Tournament.csproj",
|
||||||
"osu.Game\\osu.Game.csproj",
|
"osu.Game\\osu.Game.csproj",
|
||||||
|
|
||||||
"Templates\\Rulesets\\ruleset-empty\\osu.Game.Rulesets.EmptyFreeform\\osu.Game.Rulesets.EmptyFreeform.csproj",
|
|
||||||
"Templates\\Rulesets\\ruleset-empty\\osu.Game.Rulesets.EmptyFreeform.Tests\\osu.Game.Rulesets.EmptyFreeform.Tests.csproj",
|
"Templates\\Rulesets\\ruleset-empty\\osu.Game.Rulesets.EmptyFreeform.Tests\\osu.Game.Rulesets.EmptyFreeform.Tests.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-example\\osu.Game.Rulesets.Pippidon\\osu.Game.Rulesets.Pippidon.csproj",
|
"Templates\\Rulesets\\ruleset-empty\\osu.Game.Rulesets.EmptyFreeform\\osu.Game.Rulesets.EmptyFreeform.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-example\\osu.Game.Rulesets.Pippidon.Tests\\osu.Game.Rulesets.Pippidon.Tests.csproj",
|
"Templates\\Rulesets\\ruleset-example\\osu.Game.Rulesets.Pippidon.Tests\\osu.Game.Rulesets.Pippidon.Tests.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-scrolling-empty\\osu.Game.Rulesets.EmptyScrolling\\osu.Game.Rulesets.EmptyScrolling.csproj",
|
"Templates\\Rulesets\\ruleset-example\\osu.Game.Rulesets.Pippidon\\osu.Game.Rulesets.Pippidon.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-scrolling-empty\\osu.Game.Rulesets.EmptyScrolling.Tests\\osu.Game.Rulesets.EmptyScrolling.Tests.csproj",
|
"Templates\\Rulesets\\ruleset-scrolling-empty\\osu.Game.Rulesets.EmptyScrolling.Tests\\osu.Game.Rulesets.EmptyScrolling.Tests.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-scrolling-example\\osu.Game.Rulesets.Pippidon\\osu.Game.Rulesets.Pippidon.csproj",
|
"Templates\\Rulesets\\ruleset-scrolling-empty\\osu.Game.Rulesets.EmptyScrolling\\osu.Game.Rulesets.EmptyScrolling.csproj",
|
||||||
"Templates\\Rulesets\\ruleset-scrolling-example\\osu.Game.Rulesets.Pippidon.Tests\\osu.Game.Rulesets.Pippidon.Tests.csproj"
|
"Templates\\Rulesets\\ruleset-scrolling-example\\osu.Game.Rulesets.Pippidon.Tests\\osu.Game.Rulesets.Pippidon.Tests.csproj",
|
||||||
|
"Templates\\Rulesets\\ruleset-scrolling-example\\osu.Game.Rulesets.Pippidon\\osu.Game.Rulesets.Pippidon.csproj"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -122,7 +122,7 @@ namespace osu.Game.Graphics.Containers
|
|||||||
|
|
||||||
protected override void PopIn()
|
protected override void PopIn()
|
||||||
{
|
{
|
||||||
foreach (var w in wavesContainer.Children)
|
foreach (var w in wavesContainer)
|
||||||
w.Show();
|
w.Show();
|
||||||
|
|
||||||
contentContainer.MoveToY(0, APPEAR_DURATION, Easing.OutQuint);
|
contentContainer.MoveToY(0, APPEAR_DURATION, Easing.OutQuint);
|
||||||
@ -132,7 +132,7 @@ namespace osu.Game.Graphics.Containers
|
|||||||
|
|
||||||
protected override void PopOut()
|
protected override void PopOut()
|
||||||
{
|
{
|
||||||
foreach (var w in wavesContainer.Children)
|
foreach (var w in wavesContainer)
|
||||||
w.Hide();
|
w.Hide();
|
||||||
|
|
||||||
contentContainer.MoveToY(2, DISAPPEAR_DURATION, Easing.In);
|
contentContainer.MoveToY(2, DISAPPEAR_DURATION, Easing.In);
|
||||||
|
@ -33,7 +33,7 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
|
|
||||||
Current.ValueChanged += index =>
|
Current.ValueChanged += index =>
|
||||||
{
|
{
|
||||||
foreach (var t in TabContainer.Children.OfType<BreadcrumbTabItem>())
|
foreach (var t in TabContainer.OfType<BreadcrumbTabItem>())
|
||||||
{
|
{
|
||||||
int tIndex = TabContainer.IndexOf(t);
|
int tIndex = TabContainer.IndexOf(t);
|
||||||
int tabIndex = TabContainer.IndexOf(TabMap[index.NewValue]);
|
int tabIndex = TabContainer.IndexOf(TabMap[index.NewValue]);
|
||||||
|
@ -37,7 +37,7 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
|
|
||||||
if (Dropdown is IHasAccentColour dropdown)
|
if (Dropdown is IHasAccentColour dropdown)
|
||||||
dropdown.AccentColour = value;
|
dropdown.AccentColour = value;
|
||||||
foreach (var i in TabContainer.Children.OfType<IHasAccentColour>())
|
foreach (var i in TabContainer.OfType<IHasAccentColour>())
|
||||||
i.AccentColour = value;
|
i.AccentColour = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -48,7 +48,7 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
|
|
||||||
protected override TabItem<T> CreateTabItem(T value) => new OsuTabItem(value);
|
protected override TabItem<T> CreateTabItem(T value) => new OsuTabItem(value);
|
||||||
|
|
||||||
protected virtual float StripWidth => TabContainer.Children.Sum(c => c.IsPresent ? c.DrawWidth + TabContainer.Spacing.X : 0) - TabContainer.Spacing.X;
|
protected virtual float StripWidth => TabContainer.Sum(c => c.IsPresent ? c.DrawWidth + TabContainer.Spacing.X : 0) - TabContainer.Spacing.X;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether entries should be automatically populated if <typeparamref name="T"/> is an <see cref="Enum"/> type.
|
/// Whether entries should be automatically populated if <typeparamref name="T"/> is an <see cref="Enum"/> type.
|
||||||
|
@ -101,7 +101,7 @@ namespace osu.Game.Graphics.UserInterface
|
|||||||
public void StopAnimation()
|
public void StopAnimation()
|
||||||
{
|
{
|
||||||
animate(current);
|
animate(current);
|
||||||
foreach (var star in stars.Children)
|
foreach (var star in stars)
|
||||||
star.FinishTransforms(true);
|
star.FinishTransforms(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -287,7 +287,7 @@ namespace osu.Game.Online.Leaderboards
|
|||||||
|
|
||||||
double delay = 0;
|
double delay = 0;
|
||||||
|
|
||||||
foreach (var s in scoreFlowContainer.Children)
|
foreach (var s in scoreFlowContainer)
|
||||||
{
|
{
|
||||||
using (s.BeginDelayedSequence(delay))
|
using (s.BeginDelayedSequence(delay))
|
||||||
s.Show();
|
s.Show();
|
||||||
@ -384,7 +384,7 @@ namespace osu.Game.Online.Leaderboards
|
|||||||
if (scoreFlowContainer == null)
|
if (scoreFlowContainer == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
foreach (var c in scoreFlowContainer.Children)
|
foreach (var c in scoreFlowContainer)
|
||||||
{
|
{
|
||||||
float topY = c.ToSpaceOfOtherDrawable(Vector2.Zero, scoreFlowContainer).Y;
|
float topY = c.ToSpaceOfOtherDrawable(Vector2.Zero, scoreFlowContainer).Y;
|
||||||
float bottomY = topY + LeaderboardScore.HEIGHT;
|
float bottomY = topY + LeaderboardScore.HEIGHT;
|
||||||
|
@ -63,7 +63,7 @@ namespace osu.Game.Overlays.Chat.Listing
|
|||||||
flow.ChildrenEnumerable = newChannels.Where(c => c.Type == ChannelType.Public)
|
flow.ChildrenEnumerable = newChannels.Where(c => c.Type == ChannelType.Public)
|
||||||
.Select(c => new ChannelListingItem(c));
|
.Select(c => new ChannelListingItem(c));
|
||||||
|
|
||||||
foreach (var item in flow.Children)
|
foreach (var item in flow)
|
||||||
{
|
{
|
||||||
item.OnRequestJoin += channel => OnRequestJoin?.Invoke(channel);
|
item.OnRequestJoin += channel => OnRequestJoin?.Invoke(channel);
|
||||||
item.OnRequestLeave += channel => OnRequestLeave?.Invoke(channel);
|
item.OnRequestLeave += channel => OnRequestLeave?.Invoke(channel);
|
||||||
|
@ -41,7 +41,7 @@ namespace osu.Game.Overlays
|
|||||||
|
|
||||||
protected override bool OnHover(HoverEvent e)
|
protected override bool OnHover(HoverEvent e)
|
||||||
{
|
{
|
||||||
foreach (var streamBadge in TabContainer.Children.OfType<OverlayStreamItem<T>>())
|
foreach (var streamBadge in TabContainer.OfType<OverlayStreamItem<T>>())
|
||||||
streamBadge.UserHoveringArea = true;
|
streamBadge.UserHoveringArea = true;
|
||||||
|
|
||||||
return base.OnHover(e);
|
return base.OnHover(e);
|
||||||
@ -49,7 +49,7 @@ namespace osu.Game.Overlays
|
|||||||
|
|
||||||
protected override void OnHoverLost(HoverLostEvent e)
|
protected override void OnHoverLost(HoverLostEvent e)
|
||||||
{
|
{
|
||||||
foreach (var streamBadge in TabContainer.Children.OfType<OverlayStreamItem<T>>())
|
foreach (var streamBadge in TabContainer.OfType<OverlayStreamItem<T>>())
|
||||||
streamBadge.UserHoveringArea = false;
|
streamBadge.UserHoveringArea = false;
|
||||||
|
|
||||||
base.OnHoverLost(e);
|
base.OnHoverLost(e);
|
||||||
|
@ -343,7 +343,7 @@ namespace osu.Game.Screens.Menu
|
|||||||
{
|
{
|
||||||
buttonArea.ButtonSystemState = state;
|
buttonArea.ButtonSystemState = state;
|
||||||
|
|
||||||
foreach (var b in buttonArea.Children.OfType<MainMenuButton>())
|
foreach (var b in buttonArea.OfType<MainMenuButton>())
|
||||||
b.ButtonSystemState = state;
|
b.ButtonSystemState = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ namespace osu.Game.Screens.Play.HUD
|
|||||||
if (!scroll.IsScrolledToEnd()) fadeBottom -= panel_height;
|
if (!scroll.IsScrolledToEnd()) fadeBottom -= panel_height;
|
||||||
|
|
||||||
// logic is mostly shared with Leaderboard, copied here for simplicity.
|
// logic is mostly shared with Leaderboard, copied here for simplicity.
|
||||||
foreach (var c in Flow.Children)
|
foreach (var c in Flow)
|
||||||
{
|
{
|
||||||
float topY = c.ToSpaceOfOtherDrawable(Vector2.Zero, Flow).Y;
|
float topY = c.ToSpaceOfOtherDrawable(Vector2.Zero, Flow).Y;
|
||||||
float bottomY = topY + panel_height;
|
float bottomY = topY + panel_height;
|
||||||
|
@ -64,7 +64,7 @@ namespace osu.Game.Screens.Play.HUD.JudgementCounter
|
|||||||
|
|
||||||
CounterFlow.Direction = convertedDirection;
|
CounterFlow.Direction = convertedDirection;
|
||||||
|
|
||||||
foreach (var counter in CounterFlow.Children)
|
foreach (var counter in CounterFlow)
|
||||||
counter.Direction.Value = convertedDirection;
|
counter.Direction.Value = convertedDirection;
|
||||||
}, true);
|
}, true);
|
||||||
|
|
||||||
|
@ -242,7 +242,7 @@ namespace osu.Game.Screens.Select.Carousel
|
|||||||
|
|
||||||
bool isSelected = Item?.State.Value == CarouselItemState.Selected;
|
bool isSelected = Item?.State.Value == CarouselItemState.Selected;
|
||||||
|
|
||||||
foreach (var panel in beatmapContainer.Children)
|
foreach (var panel in beatmapContainer)
|
||||||
{
|
{
|
||||||
Debug.Assert(panel.Item != null);
|
Debug.Assert(panel.Item != null);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user