// Copyright (c) ppy Pty Ltd . 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.Extensions; using osu.Framework.Graphics; using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Cursor; using osu.Framework.Graphics.Shapes; using osu.Framework.Graphics.UserInterface; using osu.Framework.Localisation; using osu.Game.Graphics.Containers; using osu.Game.Graphics.Sprites; using osu.Game.Graphics.UserInterface; using osuTK; namespace osu.Game.Graphics.UserInterfaceV2 { /// /// A component which displays a colour along with related description text. /// public class ColourDisplay : CompositeDrawable, IHasCurrentValue { /// /// Invoked when the user has requested the colour corresponding to this /// to be removed from its palette. /// public event Action DeleteRequested; private readonly BindableWithCurrent current = new BindableWithCurrent(); private OsuSpriteText colourName; public Bindable Current { get => current.Current; set => current.Current = value; } private LocalisableString name; public LocalisableString ColourName { get => name; set { if (name == value) return; name = value; colourName.Text = name; } } [BackgroundDependencyLoader] private void load() { AutoSizeAxes = Axes.Y; Width = 100; InternalChild = new FillFlowContainer { RelativeSizeAxes = Axes.X, AutoSizeAxes = Axes.Y, Direction = FillDirection.Vertical, Spacing = new Vector2(0, 10), Children = new Drawable[] { new ColourCircle { Current = { BindTarget = Current }, DeleteRequested = () => DeleteRequested?.Invoke(this) }, colourName = new OsuSpriteText { Anchor = Anchor.TopCentre, Origin = Anchor.TopCentre } } }; } private class ColourCircle : OsuClickableContainer, IHasPopover, IHasContextMenu { public Bindable Current { get; } = new Bindable(); public Action DeleteRequested { get; set; } private readonly Box fill; private readonly OsuSpriteText colourHexCode; public ColourCircle() { RelativeSizeAxes = Axes.X; Height = 100; CornerRadius = 50; Masking = true; Action = this.ShowPopover; Children = new Drawable[] { fill = new Box { RelativeSizeAxes = Axes.Both }, colourHexCode = new OsuSpriteText { Anchor = Anchor.Centre, Origin = Anchor.Centre, Font = OsuFont.Default.With(size: 12) } }; } protected override void LoadComplete() { base.LoadComplete(); Current.BindValueChanged(_ => updateColour(), true); } private void updateColour() { fill.Colour = Current.Value; colourHexCode.Text = Current.Value.ToHex(); colourHexCode.Colour = OsuColour.ForegroundTextColourFor(Current.Value); } public Popover GetPopover() => new OsuPopover(false) { Child = new OsuColourPicker { Current = { BindTarget = Current } } }; public MenuItem[] ContextMenuItems => new MenuItem[] { new OsuMenuItem("Delete", MenuItemType.Destructive, () => DeleteRequested?.Invoke()) }; } } }