From 24e33abcbf281135415f2e7122c0529fb9c3c8e5 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Wed, 19 Feb 2020 14:31:32 +0900 Subject: [PATCH] Fix banana colouring for skins --- .../Objects/Drawable/DrawableBanana.cs | 34 +++++++++++++++++++ .../Objects/Drawable/FruitPiece.cs | 22 ++---------- 2 files changed, 36 insertions(+), 20 deletions(-) diff --git a/osu.Game.Rulesets.Catch/Objects/Drawable/DrawableBanana.cs b/osu.Game.Rulesets.Catch/Objects/Drawable/DrawableBanana.cs index 5afdb14888..4b4e381efd 100644 --- a/osu.Game.Rulesets.Catch/Objects/Drawable/DrawableBanana.cs +++ b/osu.Game.Rulesets.Catch/Objects/Drawable/DrawableBanana.cs @@ -1,6 +1,10 @@ // Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence. // See the LICENCE file in the repository root for full licence text. +using osu.Framework.Bindables; +using osu.Framework.Utils; +using osuTK.Graphics; + namespace osu.Game.Rulesets.Catch.Objects.Drawable { public class DrawableBanana : DrawableFruit @@ -9,5 +13,35 @@ namespace osu.Game.Rulesets.Catch.Objects.Drawable : base(h) { } + + protected override void LoadComplete() + { + base.LoadComplete(); + + AccentColour.BindValueChanged(accentChanged, true); + } + + private Color4? colour; + + private void accentChanged(ValueChangedEvent obj) + { + // override any external colour changes with banananana + AccentColour.Value = (colour ??= getBananaColour()); + } + + private Color4 getBananaColour() + { + switch (RNG.Next(0, 3)) + { + default: + return new Color4(255, 240, 0, 255); + + case 1: + return new Color4(255, 192, 0, 255); + + case 2: + return new Color4(214, 221, 28, 255); + } + } } } diff --git a/osu.Game.Rulesets.Catch/Objects/Drawable/FruitPiece.cs b/osu.Game.Rulesets.Catch/Objects/Drawable/FruitPiece.cs index 0898c90bc8..24f558db78 100644 --- a/osu.Game.Rulesets.Catch/Objects/Drawable/FruitPiece.cs +++ b/osu.Game.Rulesets.Catch/Objects/Drawable/FruitPiece.cs @@ -7,7 +7,6 @@ using osu.Framework.Bindables; using osu.Framework.Graphics; using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Shapes; -using osu.Framework.Utils; using osu.Game.Rulesets.Catch.Objects.Drawable.Pieces; using osu.Game.Rulesets.Objects.Drawables; using osuTK; @@ -250,8 +249,6 @@ namespace osu.Game.Rulesets.Catch.Objects.Drawable case FruitVisualRepresentation.Banana: - Color4 bananaColour = getBananaColour(); - return new Container { RelativeSizeAxes = Axes.Both, @@ -259,13 +256,13 @@ namespace osu.Game.Rulesets.Catch.Objects.Drawable { new Pulp { - AccentColour = { Value = bananaColour }, + AccentColour = { BindTarget = accentColour }, Size = new Vector2(small_pulp), Y = -0.3f }, new Pulp { - AccentColour = { Value = bananaColour }, + AccentColour = { BindTarget = accentColour }, Size = new Vector2(large_pulp_4 * 0.8f, large_pulp_4 * 2.5f), Y = 0.05f, }, @@ -273,20 +270,5 @@ namespace osu.Game.Rulesets.Catch.Objects.Drawable }; } } - - private Color4 getBananaColour() - { - switch (RNG.Next(0, 3)) - { - default: - return new Color4(255, 240, 0, 255); - - case 1: - return new Color4(255, 192, 0, 255); - - case 2: - return new Color4(214, 221, 28, 255); - } - } } }