1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-11 01:52:56 +08:00
osu-lazer/osu.Game/Overlays/OverlayRulesetTabItem.cs

113 lines
3.3 KiB
C#
Raw Normal View History

2020-01-02 03:49:04 +08:00
// 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 osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.UserInterface;
using osu.Framework.Input.Events;
using osu.Game.Graphics.UserInterface;
using osu.Game.Rulesets;
using osuTK.Graphics;
using osuTK;
using osu.Framework.Allocation;
using osu.Framework.Audio;
using osu.Framework.Audio.Sample;
2022-04-30 20:35:04 +08:00
using osu.Framework.Graphics.Cursor;
using osu.Framework.Localisation;
2022-04-29 17:19:22 +08:00
using osu.Game.Graphics.Containers;
2020-01-02 03:49:04 +08:00
namespace osu.Game.Overlays
{
2022-11-24 13:32:20 +08:00
public partial class OverlayRulesetTabItem : TabItem<RulesetInfo>, IHasTooltip
2020-01-02 03:49:04 +08:00
{
private Color4 accentColour;
2020-01-02 03:49:04 +08:00
protected virtual Color4 AccentColour
2020-01-02 03:49:04 +08:00
{
get => accentColour;
set
{
accentColour = value;
2022-04-29 17:19:22 +08:00
icon.FadeColour(value, 120, Easing.OutQuint);
}
2020-01-02 03:49:04 +08:00
}
2020-02-03 14:13:21 +08:00
protected override Container<Drawable> Content { get; }
[Resolved]
2023-06-23 00:37:25 +08:00
private OverlayColourProvider colourProvider { get; set; } = null!;
2020-01-02 03:49:04 +08:00
2022-04-29 17:19:22 +08:00
private readonly Drawable icon;
2020-02-03 14:13:21 +08:00
2022-04-30 20:35:04 +08:00
public LocalisableString TooltipText => Value.Name;
private Sample selectSample = null!;
2020-01-02 03:49:04 +08:00
public OverlayRulesetTabItem(RulesetInfo value)
: base(value)
{
AutoSizeAxes = Axes.Both;
AddRangeInternal(new Drawable[]
{
2020-02-03 14:13:21 +08:00
Content = new FillFlowContainer
2020-01-02 03:49:04 +08:00
{
AutoSizeAxes = Axes.Both,
Direction = FillDirection.Horizontal,
2022-04-30 17:23:08 +08:00
Spacing = new Vector2(4, 0),
2022-04-29 17:19:22 +08:00
Child = icon = new ConstrainedIconContainer
2020-01-02 03:49:04 +08:00
{
Anchor = Anchor.Centre,
2022-04-29 17:19:22 +08:00
Origin = Anchor.Centre,
Size = new Vector2(20f),
Icon = value.CreateInstance().CreateIcon(),
},
2020-01-02 03:49:04 +08:00
},
new HoverSounds(HoverSampleSet.TabSelect)
2020-01-02 03:49:04 +08:00
});
Enabled.Value = true;
}
[BackgroundDependencyLoader]
private void load(AudioManager audio)
{
selectSample = audio.Samples.Get(@"UI/tabselect-select");
}
protected override void LoadComplete()
2020-01-02 03:49:04 +08:00
{
base.LoadComplete();
Enabled.BindValueChanged(_ => updateState(), true);
2020-01-02 03:49:04 +08:00
}
2022-04-30 20:36:15 +08:00
public override bool PropagatePositionalInputSubTree => Enabled.Value && base.PropagatePositionalInputSubTree;
2020-02-04 11:53:57 +08:00
2020-01-02 03:49:04 +08:00
protected override bool OnHover(HoverEvent e)
{
base.OnHover(e);
updateState();
2020-01-02 03:49:04 +08:00
return true;
}
protected override void OnHoverLost(HoverLostEvent e)
{
base.OnHoverLost(e);
updateState();
2020-01-02 03:49:04 +08:00
}
protected override void OnActivated() => updateState();
2020-01-02 03:49:04 +08:00
protected override void OnDeactivated() => updateState();
2020-01-02 03:49:04 +08:00
protected override void OnActivatedByUser() => selectSample.Play();
private void updateState()
2020-01-02 03:49:04 +08:00
{
2020-02-04 05:55:41 +08:00
AccentColour = Enabled.Value ? getActiveColour() : colourProvider.Foreground1;
2020-01-02 03:49:04 +08:00
}
2020-02-04 05:55:41 +08:00
private Color4 getActiveColour() => IsHovered || Active.Value ? Color4.White : colourProvider.Highlight1;
2020-01-02 03:49:04 +08:00
}
}