mirror of
https://github.com/ppy/osu.git
synced 2025-01-07 23:23:12 +08:00
Bring across tournament score display for game usage
This commit is contained in:
parent
e08b1223ab
commit
aa4c6b9341
@ -16,7 +16,7 @@ namespace osu.Game.Tournament.Tests.Components
|
|||||||
|
|
||||||
public TestSceneMatchScoreDisplay()
|
public TestSceneMatchScoreDisplay()
|
||||||
{
|
{
|
||||||
Add(new MatchScoreDisplay
|
Add(new TournamentMatchScoreDisplay
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
|
@ -16,7 +16,8 @@ using osuTK;
|
|||||||
|
|
||||||
namespace osu.Game.Tournament.Screens.Gameplay.Components
|
namespace osu.Game.Tournament.Screens.Gameplay.Components
|
||||||
{
|
{
|
||||||
public class MatchScoreDisplay : CompositeDrawable
|
// TODO: Update to derive from osu-side class?
|
||||||
|
public class TournamentMatchScoreDisplay : CompositeDrawable
|
||||||
{
|
{
|
||||||
private const float bar_height = 18;
|
private const float bar_height = 18;
|
||||||
|
|
||||||
@ -29,7 +30,7 @@ namespace osu.Game.Tournament.Screens.Gameplay.Components
|
|||||||
private readonly Drawable score1Bar;
|
private readonly Drawable score1Bar;
|
||||||
private readonly Drawable score2Bar;
|
private readonly Drawable score2Bar;
|
||||||
|
|
||||||
public MatchScoreDisplay()
|
public TournamentMatchScoreDisplay()
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.X;
|
RelativeSizeAxes = Axes.X;
|
||||||
AutoSizeAxes = Axes.Y;
|
AutoSizeAxes = Axes.Y;
|
@ -86,7 +86,7 @@ namespace osu.Game.Tournament.Screens.Gameplay
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
scoreDisplay = new MatchScoreDisplay
|
scoreDisplay = new TournamentMatchScoreDisplay
|
||||||
{
|
{
|
||||||
Y = -147,
|
Y = -147,
|
||||||
Anchor = Anchor.BottomCentre,
|
Anchor = Anchor.BottomCentre,
|
||||||
@ -148,7 +148,7 @@ namespace osu.Game.Tournament.Screens.Gameplay
|
|||||||
}
|
}
|
||||||
|
|
||||||
private ScheduledDelegate scheduledOperation;
|
private ScheduledDelegate scheduledOperation;
|
||||||
private MatchScoreDisplay scoreDisplay;
|
private TournamentMatchScoreDisplay scoreDisplay;
|
||||||
|
|
||||||
private TourneyState lastState;
|
private TourneyState lastState;
|
||||||
private MatchHeader header;
|
private MatchHeader header;
|
||||||
|
153
osu.Game/Screens/Play/HUD/MatchScoreDisplay.cs
Normal file
153
osu.Game/Screens/Play/HUD/MatchScoreDisplay.cs
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Bindables;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Game.Graphics;
|
||||||
|
using osu.Game.Graphics.Sprites;
|
||||||
|
using osu.Game.Graphics.UserInterface;
|
||||||
|
using osuTK;
|
||||||
|
|
||||||
|
namespace osu.Game.Screens.Play.HUD
|
||||||
|
{
|
||||||
|
public class MatchScoreDisplay : CompositeDrawable
|
||||||
|
{
|
||||||
|
private const float bar_height = 18;
|
||||||
|
|
||||||
|
public BindableInt Team1Score = new BindableInt();
|
||||||
|
public BindableInt Team2Score = new BindableInt();
|
||||||
|
|
||||||
|
private MatchScoreCounter score1Text;
|
||||||
|
private MatchScoreCounter score2Text;
|
||||||
|
|
||||||
|
private Drawable score1Bar;
|
||||||
|
private Drawable score2Bar;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuColour colours)
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.X;
|
||||||
|
AutoSizeAxes = Axes.Y;
|
||||||
|
|
||||||
|
InternalChildren = new[]
|
||||||
|
{
|
||||||
|
new Box
|
||||||
|
{
|
||||||
|
Name = "top bar red (static)",
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Height = bar_height / 4,
|
||||||
|
Width = 0.5f,
|
||||||
|
Colour = colours.TeamColourRed,
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopRight
|
||||||
|
},
|
||||||
|
new Box
|
||||||
|
{
|
||||||
|
Name = "top bar blue (static)",
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Height = bar_height / 4,
|
||||||
|
Width = 0.5f,
|
||||||
|
Colour = colours.TeamColourBlue,
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopLeft
|
||||||
|
},
|
||||||
|
score1Bar = new Box
|
||||||
|
{
|
||||||
|
Name = "top bar red",
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Height = bar_height,
|
||||||
|
Width = 0,
|
||||||
|
Colour = colours.TeamColourRed,
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopRight
|
||||||
|
},
|
||||||
|
score1Text = new MatchScoreCounter
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopCentre
|
||||||
|
},
|
||||||
|
score2Bar = new Box
|
||||||
|
{
|
||||||
|
Name = "top bar blue",
|
||||||
|
RelativeSizeAxes = Axes.X,
|
||||||
|
Height = bar_height,
|
||||||
|
Width = 0,
|
||||||
|
Colour = colours.TeamColourBlue,
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopLeft
|
||||||
|
},
|
||||||
|
score2Text = new MatchScoreCounter
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopCentre,
|
||||||
|
Origin = Anchor.TopCentre
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LoadComplete()
|
||||||
|
{
|
||||||
|
base.LoadComplete();
|
||||||
|
|
||||||
|
Team1Score.BindValueChanged(_ => updateScores());
|
||||||
|
Team2Score.BindValueChanged(_ => updateScores());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateScores()
|
||||||
|
{
|
||||||
|
score1Text.Current.Value = Team1Score.Value;
|
||||||
|
score2Text.Current.Value = Team2Score.Value;
|
||||||
|
|
||||||
|
var winningText = Team1Score.Value > Team2Score.Value ? score1Text : score2Text;
|
||||||
|
var losingText = Team1Score.Value <= Team2Score.Value ? score1Text : score2Text;
|
||||||
|
|
||||||
|
winningText.Winning = true;
|
||||||
|
losingText.Winning = false;
|
||||||
|
|
||||||
|
var winningBar = Team1Score.Value > Team2Score.Value ? score1Bar : score2Bar;
|
||||||
|
var losingBar = Team1Score.Value <= Team2Score.Value ? score1Bar : score2Bar;
|
||||||
|
|
||||||
|
var diff = Math.Max(Team1Score.Value, Team2Score.Value) - Math.Min(Team1Score.Value, Team2Score.Value);
|
||||||
|
|
||||||
|
losingBar.ResizeWidthTo(0, 400, Easing.OutQuint);
|
||||||
|
winningBar.ResizeWidthTo(Math.Min(0.4f, MathF.Pow(diff / 1500000f, 0.5f) / 2), 400, Easing.OutQuint);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void UpdateAfterChildren()
|
||||||
|
{
|
||||||
|
base.UpdateAfterChildren();
|
||||||
|
score1Text.X = -Math.Max(5 + score1Text.DrawWidth / 2, score1Bar.DrawWidth);
|
||||||
|
score2Text.X = Math.Max(5 + score2Text.DrawWidth / 2, score2Bar.DrawWidth);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class MatchScoreCounter : ScoreCounter
|
||||||
|
{
|
||||||
|
private OsuSpriteText displayedSpriteText;
|
||||||
|
|
||||||
|
public MatchScoreCounter()
|
||||||
|
{
|
||||||
|
Margin = new MarginPadding { Top = bar_height, Horizontal = 10 };
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool Winning
|
||||||
|
{
|
||||||
|
set => updateFont(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override OsuSpriteText CreateSpriteText() => base.CreateSpriteText().With(s =>
|
||||||
|
{
|
||||||
|
displayedSpriteText = s;
|
||||||
|
displayedSpriteText.Spacing = new Vector2(-6);
|
||||||
|
updateFont(false);
|
||||||
|
});
|
||||||
|
|
||||||
|
private void updateFont(bool winning)
|
||||||
|
=> displayedSpriteText.Font = winning
|
||||||
|
? OsuFont.Torus.With(weight: FontWeight.Bold, size: 50, fixedWidth: true)
|
||||||
|
: OsuFont.Torus.With(weight: FontWeight.Regular, size: 40, fixedWidth: true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user