2021-04-18 17:29:04 +00: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.
|
|
|
|
|
2021-04-18 18:15:30 +00:00
|
|
|
using System.Linq;
|
2021-04-18 17:29:04 +00:00
|
|
|
using osu.Framework.Allocation;
|
|
|
|
using osu.Framework.Bindables;
|
|
|
|
using osu.Framework.Graphics;
|
|
|
|
using osu.Framework.Graphics.Containers;
|
2021-04-18 18:15:30 +00:00
|
|
|
using osu.Game.Graphics.Sprites;
|
2021-04-18 17:29:04 +00:00
|
|
|
using osuTK;
|
|
|
|
using osuTK.Graphics;
|
|
|
|
|
|
|
|
namespace osu.Game.Graphics.UserInterfaceV2
|
|
|
|
{
|
2021-04-19 03:37:56 +00:00
|
|
|
/// <summary>
|
|
|
|
/// A component which displays a collection of colours in individual <see cref="ColourDisplay"/>s.
|
|
|
|
/// </summary>
|
2021-04-18 17:29:04 +00:00
|
|
|
public class ColourPalette : CompositeDrawable
|
|
|
|
{
|
|
|
|
public BindableList<Color4> Colours { get; } = new BindableList<Color4>();
|
|
|
|
|
2021-04-18 17:56:03 +00:00
|
|
|
private string colourNamePrefix = "Colour";
|
|
|
|
|
|
|
|
public string ColourNamePrefix
|
|
|
|
{
|
|
|
|
get => colourNamePrefix;
|
|
|
|
set
|
|
|
|
{
|
|
|
|
if (colourNamePrefix == value)
|
|
|
|
return;
|
|
|
|
|
|
|
|
colourNamePrefix = value;
|
|
|
|
|
|
|
|
if (IsLoaded)
|
|
|
|
reindexItems();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-18 17:29:04 +00:00
|
|
|
private FillFlowContainer<ColourDisplay> palette;
|
2021-04-18 18:15:30 +00:00
|
|
|
private Container placeholder;
|
2021-04-18 17:29:04 +00:00
|
|
|
|
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
private void load()
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.X;
|
|
|
|
AutoSizeAxes = Axes.Y;
|
|
|
|
|
2021-04-18 18:15:30 +00:00
|
|
|
InternalChildren = new Drawable[]
|
2021-04-18 17:29:04 +00:00
|
|
|
{
|
2021-04-18 18:15:30 +00:00
|
|
|
palette = new FillFlowContainer<ColourDisplay>
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.X,
|
|
|
|
AutoSizeAxes = Axes.Y,
|
|
|
|
Spacing = new Vector2(10),
|
|
|
|
Direction = FillDirection.Full
|
|
|
|
},
|
|
|
|
placeholder = new Container
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.X,
|
|
|
|
AutoSizeAxes = Axes.Y,
|
|
|
|
Child = new OsuSpriteText
|
|
|
|
{
|
|
|
|
Anchor = Anchor.CentreRight,
|
|
|
|
Origin = Anchor.CentreRight,
|
|
|
|
Text = "(none)",
|
|
|
|
Font = OsuFont.Default.With(weight: FontWeight.Bold)
|
|
|
|
}
|
|
|
|
}
|
2021-04-18 17:29:04 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override void LoadComplete()
|
|
|
|
{
|
|
|
|
base.LoadComplete();
|
|
|
|
|
|
|
|
Colours.BindCollectionChanged((_, __) => updatePalette(), true);
|
2021-04-18 18:15:30 +00:00
|
|
|
FinishTransforms(true);
|
2021-04-18 17:29:04 +00:00
|
|
|
}
|
|
|
|
|
2021-04-18 18:15:30 +00:00
|
|
|
private const int fade_duration = 200;
|
|
|
|
|
2021-04-18 17:29:04 +00:00
|
|
|
private void updatePalette()
|
|
|
|
{
|
|
|
|
palette.Clear();
|
|
|
|
|
2021-04-18 18:15:30 +00:00
|
|
|
if (Colours.Any())
|
|
|
|
{
|
|
|
|
palette.FadeIn(fade_duration, Easing.OutQuint);
|
|
|
|
placeholder.FadeOut(fade_duration, Easing.OutQuint);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
palette.FadeOut(fade_duration, Easing.OutQuint);
|
|
|
|
placeholder.FadeIn(fade_duration, Easing.OutQuint);
|
|
|
|
}
|
|
|
|
|
2021-04-18 17:29:04 +00:00
|
|
|
foreach (var item in Colours)
|
|
|
|
{
|
|
|
|
palette.Add(new ColourDisplay
|
|
|
|
{
|
|
|
|
Current = { Value = item }
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
reindexItems();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void reindexItems()
|
|
|
|
{
|
|
|
|
int index = 1;
|
|
|
|
|
|
|
|
foreach (var colour in palette)
|
|
|
|
{
|
2021-04-18 17:56:03 +00:00
|
|
|
colour.ColourName = $"{colourNamePrefix} {index}";
|
2021-04-18 17:29:04 +00:00
|
|
|
index += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|