1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-12 21:52:55 +08:00

Merge branch 'master' into osulegacydecoder-parser

This commit is contained in:
Dean Herbert 2017-08-03 16:30:37 +09:00 committed by GitHub
commit 248486f8f9
55 changed files with 327 additions and 187 deletions

View File

@ -31,10 +31,10 @@ namespace osu.Desktop.VisualTests.Tests
int i = 50; int i = 50;
foreach (FontAwesome fa in Enum.GetValues(typeof(FontAwesome))) foreach (FontAwesome fa in Enum.GetValues(typeof(FontAwesome)))
{ {
flow.Add(new TextAwesome flow.Add(new SpriteIcon
{ {
Icon = fa, Icon = fa,
TextSize = 60, Size = new Vector2(60),
Colour = new Color4( Colour = new Color4(
Math.Max(0.5f, RNG.NextSingle()), Math.Max(0.5f, RNG.NextSingle()),
Math.Max(0.5f, RNG.NextSingle()), Math.Max(0.5f, RNG.NextSingle()),

View File

@ -209,13 +209,13 @@ namespace osu.Desktop.Overlays
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = ColourInfo.GradientVertical(colours.YellowDark, colours.Yellow) Colour = ColourInfo.GradientVertical(colours.YellowDark, colours.Yellow)
}, },
new TextAwesome new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = FontAwesome.fa_upload, Icon = FontAwesome.fa_upload,
Colour = Color4.White, Colour = Color4.White,
TextSize = 20 Size = new Vector2(20),
} }
}); });
} }

View File

@ -10,6 +10,7 @@ using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.UI; using osu.Game.Rulesets.UI;
using osu.Game.Screens.Play; using osu.Game.Screens.Play;
using System.Collections.Generic; using System.Collections.Generic;
using osu.Framework.Graphics;
using osu.Game.Rulesets.Catch.Scoring; using osu.Game.Rulesets.Catch.Scoring;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
@ -85,7 +86,7 @@ namespace osu.Game.Rulesets.Catch
public override string Description => "osu!catch"; public override string Description => "osu!catch";
public override FontAwesome Icon => FontAwesome.fa_osu_fruits_o; public override Drawable CreateIcon() => new SpriteIcon { Icon = FontAwesome.fa_osu_fruits_o };
public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[] public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[]
{ {

View File

@ -2,13 +2,14 @@
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Graphics;
using osu.Game.Rulesets.Mania.Mods; using osu.Game.Rulesets.Mania.Mods;
using osu.Game.Rulesets.Mania.UI; using osu.Game.Rulesets.Mania.UI;
using osu.Game.Rulesets.Mods; using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.UI; using osu.Game.Rulesets.UI;
using osu.Game.Screens.Play; using osu.Game.Screens.Play;
using System.Collections.Generic; using System.Collections.Generic;
using osu.Framework.Graphics;
using osu.Game.Graphics;
using osu.Game.Rulesets.Mania.Scoring; using osu.Game.Rulesets.Mania.Scoring;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
@ -106,7 +107,7 @@ namespace osu.Game.Rulesets.Mania
public override string Description => "osu!mania"; public override string Description => "osu!mania";
public override FontAwesome Icon => FontAwesome.fa_osu_mania_o; public override Drawable CreateIcon() => new SpriteIcon { Icon = FontAwesome.fa_osu_mania_o };
public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[] { /* Todo: Should be keymod specific */ }; public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[] { /* Todo: Should be keymod specific */ };

View File

@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables
private readonly CirclePiece circle; private readonly CirclePiece circle;
private readonly GlowPiece glow; private readonly GlowPiece glow;
private readonly TextAwesome symbol; private readonly SpriteIcon symbol;
private readonly Color4 baseColour = OsuColour.FromHex(@"002c3c"); private readonly Color4 baseColour = OsuColour.FromHex(@"002c3c");
private readonly Color4 fillColour = OsuColour.FromHex(@"005b7c"); private readonly Color4 fillColour = OsuColour.FromHex(@"005b7c");
@ -64,12 +64,11 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
}, },
new RingPiece(), new RingPiece(),
symbol = new TextAwesome symbol = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
UseFullGlyphHeight = true, Size = new Vector2(48),
TextSize = 48,
Icon = FontAwesome.fa_asterisk, Icon = FontAwesome.fa_asterisk,
Shadow = false, Shadow = false,
}, },

View File

@ -4,6 +4,7 @@
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Game.Graphics; using osu.Game.Graphics;
using OpenTK;
namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces
{ {
@ -11,7 +12,7 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces
{ {
private readonly Slider slider; private readonly Slider slider;
private readonly bool isEnd; private readonly bool isEnd;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
public SliderBouncer(Slider slider, bool isEnd) public SliderBouncer(Slider slider, bool isEnd)
{ {
@ -24,12 +25,12 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables.Pieces
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Icon = FontAwesome.fa_eercast, Icon = FontAwesome.fa_eercast,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = 48, Size = new Vector2(48),
} }
}; };
} }

View File

@ -13,6 +13,7 @@ using osu.Game.Rulesets.UI;
using osu.Game.Screens.Play; using osu.Game.Screens.Play;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using osu.Framework.Graphics;
using osu.Game.Rulesets.Osu.Scoring; using osu.Game.Rulesets.Osu.Scoring;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
using osu.Game.Overlays.Settings; using osu.Game.Overlays.Settings;
@ -104,7 +105,7 @@ namespace osu.Game.Rulesets.Osu
} }
} }
public override FontAwesome Icon => FontAwesome.fa_osu_osu_o; public override Drawable CreateIcon() => new SpriteIcon { Icon = FontAwesome.fa_osu_osu_o };
public override DifficultyCalculator CreateDifficultyCalculator(Beatmap beatmap) => new OsuDifficultyCalculator(beatmap); public override DifficultyCalculator CreateDifficultyCalculator(Beatmap beatmap) => new OsuDifficultyCalculator(beatmap);

View File

@ -3,20 +3,20 @@
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Game.Graphics; using osu.Game.Graphics;
using OpenTK;
namespace osu.Game.Rulesets.Taiko.Objects.Drawables.Pieces namespace osu.Game.Rulesets.Taiko.Objects.Drawables.Pieces
{ {
/// <summary> /// <summary>
/// The symbol used for swell pieces. /// The symbol used for swell pieces.
/// </summary> /// </summary>
public class SwellSymbolPiece : TextAwesome public class SwellSymbolPiece : SpriteIcon
{ {
public SwellSymbolPiece() public SwellSymbolPiece()
{ {
Anchor = Anchor.Centre; Anchor = Anchor.Centre;
Origin = Anchor.Centre; Origin = Anchor.Centre;
UseFullGlyphHeight = true; Size = new Vector2(CirclePiece.SYMBOL_INNER_SIZE);
TextSize = CirclePiece.SYMBOL_INNER_SIZE;
Icon = FontAwesome.fa_asterisk; Icon = FontAwesome.fa_asterisk;
Shadow = false; Shadow = false;
} }

View File

@ -10,6 +10,7 @@ using osu.Game.Rulesets.Taiko.UI;
using osu.Game.Rulesets.UI; using osu.Game.Rulesets.UI;
using osu.Game.Screens.Play; using osu.Game.Screens.Play;
using System.Collections.Generic; using System.Collections.Generic;
using osu.Framework.Graphics;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
using osu.Game.Rulesets.Taiko.Scoring; using osu.Game.Rulesets.Taiko.Scoring;
@ -85,7 +86,7 @@ namespace osu.Game.Rulesets.Taiko
public override string Description => "osu!taiko"; public override string Description => "osu!taiko";
public override FontAwesome Icon => FontAwesome.fa_osu_taiko_o; public override Drawable CreateIcon() => new SpriteIcon { Icon = FontAwesome.fa_osu_taiko_o };
public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[] public override IEnumerable<KeyCounter> CreateGameplayKeys() => new KeyCounter[]
{ {

View File

@ -4,8 +4,8 @@
using osu.Framework.Allocation; using osu.Framework.Allocation;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Graphics.Containers;
using OpenTK; using OpenTK;
using OpenTK.Graphics;
namespace osu.Game.Beatmaps.Drawables namespace osu.Game.Beatmaps.Drawables
{ {
@ -22,23 +22,20 @@ namespace osu.Game.Beatmaps.Drawables
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load() private void load()
{ {
Children = new[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = Size.X, RelativeSizeAxes = Axes.Both,
Colour = AccentColour, Colour = AccentColour,
Icon = FontAwesome.fa_circle Icon = FontAwesome.fa_circle
}, },
new TextAwesome new ConstrainedIconContainer
{ {
Anchor = Anchor.Centre, RelativeSizeAxes = Axes.Both,
Origin = Anchor.Centre, Icon = beatmap.Ruleset.CreateInstance().CreateIcon()
TextSize = Size.X,
Colour = Color4.White,
Icon = beatmap.Ruleset.CreateInstance().Icon
} }
}; };
} }

View File

@ -0,0 +1,62 @@
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using System;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using OpenTK;
namespace osu.Game.Graphics.Containers
{
/// <summary>
/// Display an icon that is forced to scale to the size of this container.
/// </summary>
public class ConstrainedIconContainer : CompositeDrawable
{
public Drawable Icon
{
get
{
return InternalChild;
}
set
{
InternalChild = value;
}
}
/// <summary>
/// Determines an edge effect of this <see cref="Container"/>.
/// Edge effects are e.g. glow or a shadow.
/// Only has an effect when <see cref="CompositeDrawable.Masking"/> is true.
/// </summary>
public new EdgeEffectParameters EdgeEffect
{
get { return base.EdgeEffect; }
set { base.EdgeEffect = value; }
}
protected override void Update()
{
base.Update();
if (InternalChildren.Count > 0 && InternalChild.DrawSize.X > 0)
{
// We're modifying scale here for a few reasons
// - Guarantees correctness if BorderWidth is being used
// - If we were to use RelativeSize/FillMode, we'd need to set the Icon's RelativeSizeAxes directly.
// We can't do this because we would need access to AutoSizeAxes to set it to none.
// Other issues come up along the way too, so it's not a good solution.
var fitScale = Math.Min(DrawSize.X / InternalChild.DrawSize.X, DrawSize.Y / InternalChild.DrawSize.Y);
InternalChild.Scale = new Vector2(fitScale);
InternalChild.Anchor = Anchor.Centre;
InternalChild.Origin = Anchor.Centre;
}
}
public ConstrainedIconContainer()
{
Masking = true;
}
}
}

View File

@ -1,13 +1,70 @@
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>. // Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using osu.Game.Graphics.Sprites; using osu.Framework.Allocation;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics;
using osu.Framework.IO.Stores;
using OpenTK;
using OpenTK.Graphics;
namespace osu.Game.Graphics namespace osu.Game.Graphics
{ {
public class TextAwesome : OsuSpriteText public class SpriteIcon : CompositeDrawable
{ {
//public override FontFace FontFace => (int)Icon < 0xf000 ? FontFace.OsuFont : FontFace.FontAwesome; private readonly Sprite spriteShadow;
private readonly Sprite spriteMain;
public SpriteIcon()
{
InternalChildren = new[]
{
spriteShadow = new Sprite
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
RelativeSizeAxes = Axes.Both,
FillMode = FillMode.Fit,
Position = new Vector2(0, 0.06f),
Colour = new Color4(0f, 0f, 0f, 0.2f),
Alpha = 0
},
spriteMain = new Sprite
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
RelativeSizeAxes = Axes.Both,
FillMode = FillMode.Fit
},
};
}
private FontStore store;
[BackgroundDependencyLoader]
private void load(FontStore store)
{
this.store = store;
updateTexture();
}
private void updateTexture()
{
var texture = store?.Get(((char)icon).ToString());
spriteMain.Texture = texture;
spriteShadow.Texture = texture;
if (Size == Vector2.Zero)
Size = new Vector2(texture?.DisplayWidth ?? 0, texture?.DisplayHeight ?? 0);
}
public bool Shadow
{
get { return spriteShadow.IsPresent; }
set { spriteShadow.Alpha = value ? 1 : 0; }
}
private FontAwesome icon; private FontAwesome icon;
@ -23,7 +80,8 @@ namespace osu.Game.Graphics
if (icon == value) return; if (icon == value) return;
icon = value; icon = value;
Text = ((char)icon).ToString(); if (IsLoaded)
updateTexture();
} }
} }
} }

View File

@ -35,7 +35,7 @@ namespace osu.Game.Graphics.UserInterface
private class BreadcrumbTabItem : OsuTabItem, IStateful<Visibility> private class BreadcrumbTabItem : OsuTabItem, IStateful<Visibility>
{ {
public readonly TextAwesome Chevron; public readonly SpriteIcon Chevron;
//don't allow clicking between transitions and don't make the chevron clickable //don't allow clicking between transitions and don't make the chevron clickable
public override bool ReceiveMouseInputAt(Vector2 screenSpacePos) => Alpha == 1f && Text.ReceiveMouseInputAt(screenSpacePos); public override bool ReceiveMouseInputAt(Vector2 screenSpacePos) => Alpha == 1f && Text.ReceiveMouseInputAt(screenSpacePos);
@ -69,11 +69,11 @@ namespace osu.Game.Graphics.UserInterface
{ {
Text.TextSize = 16; Text.TextSize = 16;
Padding = new MarginPadding { Right = padding + 8 }; //padding + chevron width Padding = new MarginPadding { Right = padding + 8 }; //padding + chevron width
Add(Chevron = new TextAwesome Add(Chevron = new SpriteIcon
{ {
Anchor = Anchor.CentreRight, Anchor = Anchor.CentreRight,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
TextSize = 12, Size = new Vector2(12),
Icon = FontAwesome.fa_chevron_right, Icon = FontAwesome.fa_chevron_right,
Margin = new MarginPadding { Left = padding }, Margin = new MarginPadding { Left = padding },
Alpha = 0f, Alpha = 0f,

View File

@ -15,7 +15,7 @@ namespace osu.Game.Graphics.UserInterface
{ {
public class IconButton : OsuClickableContainer public class IconButton : OsuClickableContainer
{ {
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private readonly Box hover; private readonly Box hover;
private readonly Container content; private readonly Container content;
@ -64,11 +64,11 @@ namespace osu.Game.Graphics.UserInterface
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Alpha = 0, Alpha = 0,
}, },
icon = new TextAwesome icon = new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
TextSize = 18, Size = new Vector2(18),
} }
} }
} }

View File

@ -9,7 +9,7 @@ namespace osu.Game.Graphics.UserInterface
{ {
public class LoadingAnimation : VisibilityContainer public class LoadingAnimation : VisibilityContainer
{ {
private readonly TextAwesome spinner; private readonly SpriteIcon spinner;
public LoadingAnimation() public LoadingAnimation()
{ {
@ -20,9 +20,9 @@ namespace osu.Game.Graphics.UserInterface
Children = new Drawable[] Children = new Drawable[]
{ {
spinner = new TextAwesome spinner = new SpriteIcon
{ {
TextSize = 20, Size = new Vector2(20),
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = FontAwesome.fa_spinner Icon = FontAwesome.fa_spinner

View File

@ -10,6 +10,7 @@ using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics.UserInterface; using osu.Framework.Graphics.UserInterface;
using osu.Game.Graphics.Sprites; using osu.Game.Graphics.Sprites;
using OpenTK;
namespace osu.Game.Graphics.UserInterface namespace osu.Game.Graphics.UserInterface
{ {
@ -60,14 +61,13 @@ namespace osu.Game.Graphics.UserInterface
AutoSizeAxes = Axes.Y, AutoSizeAxes = Axes.Y,
Children = new Drawable[] Children = new Drawable[]
{ {
Chevron = new TextAwesome Chevron = new SpriteIcon
{ {
AlwaysPresent = true, AlwaysPresent = true,
Icon = FontAwesome.fa_chevron_right, Icon = FontAwesome.fa_chevron_right,
UseFullGlyphHeight = false,
Colour = Color4.Black, Colour = Color4.Black,
Alpha = 0.5f, Alpha = 0.5f,
TextSize = 8, Size = new Vector2(8),
Margin = new MarginPadding { Left = 3, Right = 3 }, Margin = new MarginPadding { Left = 3, Right = 3 },
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
@ -84,7 +84,7 @@ namespace osu.Game.Graphics.UserInterface
private Color4? accentColour; private Color4? accentColour;
protected readonly TextAwesome Chevron; protected readonly SpriteIcon Chevron;
protected readonly OsuSpriteText Label; protected readonly OsuSpriteText Label;
protected override void FormatForeground(bool hover = false) protected override void FormatForeground(bool hover = false)
@ -123,7 +123,7 @@ namespace osu.Game.Graphics.UserInterface
set { Text.Text = value; } set { Text.Text = value; }
} }
protected readonly TextAwesome Icon; protected readonly SpriteIcon Icon;
private Color4? accentColour; private Color4? accentColour;
public virtual Color4 AccentColour public virtual Color4 AccentColour
@ -152,13 +152,13 @@ namespace osu.Game.Graphics.UserInterface
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
}, },
Icon = new TextAwesome Icon = new SpriteIcon
{ {
Icon = FontAwesome.fa_chevron_down, Icon = FontAwesome.fa_chevron_down,
Anchor = Anchor.CentreRight, Anchor = Anchor.CentreRight,
Origin = Anchor.CentreRight, Origin = Anchor.CentreRight,
Margin = new MarginPadding { Right = 4 }, Margin = new MarginPadding { Right = 4 },
TextSize = 20 Size = new Vector2(20),
} }
}; };
} }

View File

@ -209,10 +209,10 @@ namespace osu.Game.Graphics.UserInterface
Foreground.Children = new Drawable[] Foreground.Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_ellipsis_h, Icon = FontAwesome.fa_ellipsis_h,
TextSize = 14, Size = new Vector2(14),
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
} }

View File

@ -21,7 +21,7 @@ namespace osu.Game.Graphics.UserInterface
{ {
private readonly Box box; private readonly Box box;
private readonly SpriteText text; private readonly SpriteText text;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private Color4? accentColour; private Color4? accentColour;
public Color4 AccentColour public Color4 AccentColour
@ -99,9 +99,9 @@ namespace osu.Game.Graphics.UserInterface
TextSize = 14, TextSize = 14,
Font = @"Exo2.0-Bold", Font = @"Exo2.0-Bold",
}, },
icon = new TextAwesome icon = new SpriteIcon
{ {
TextSize = 14, Size = new Vector2(14),
Icon = FontAwesome.fa_circle_o, Icon = FontAwesome.fa_circle_o,
Shadow = true, Shadow = true,
}, },

View File

@ -3,6 +3,7 @@
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Input; using osu.Framework.Input;
using OpenTK;
using OpenTK.Input; using OpenTK.Input;
namespace osu.Game.Graphics.UserInterface namespace osu.Game.Graphics.UserInterface
@ -19,13 +20,13 @@ namespace osu.Game.Graphics.UserInterface
Height = 35; Height = 35;
AddRange(new Drawable[] AddRange(new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_search, Icon = FontAwesome.fa_search,
Origin = Anchor.CentreRight, Origin = Anchor.CentreRight,
Anchor = Anchor.CentreRight, Anchor = Anchor.CentreRight,
Margin = new MarginPadding { Right = 10 }, Margin = new MarginPadding { Right = 10 },
TextSize = 20 Size = new Vector2(20),
} }
}); });

View File

@ -142,16 +142,16 @@ namespace osu.Game.Graphics.UserInterface
private class Star : Container private class Star : Container
{ {
public readonly TextAwesome Icon; public readonly SpriteIcon Icon;
public Star() public Star()
{ {
Size = new Vector2(star_size); Size = new Vector2(star_size);
Children = new[] Children = new[]
{ {
Icon = new TextAwesome Icon = new SpriteIcon
{ {
TextSize = star_size, Size = new Vector2(star_size),
Icon = FontAwesome.fa_star, Icon = FontAwesome.fa_star,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,

View File

@ -215,7 +215,7 @@ namespace osu.Game.Graphics.UserInterface
{ {
private const double beat_in_time = 60; private const double beat_in_time = 60;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
public FontAwesome Icon { set { icon.Icon = value; } } public FontAwesome Icon { set { icon.Icon = value; } }
@ -226,11 +226,11 @@ namespace osu.Game.Graphics.UserInterface
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = 25 Size = new Vector2(25),
} }
}; };
} }

View File

@ -21,15 +21,14 @@ namespace osu.Game.Online.Multiplayer
public override string Name => "Tag"; public override string Name => "Tag";
public override Drawable GetIcon(OsuColour colours, float size) public override Drawable GetIcon(OsuColour colours, float size)
{ {
return new TextAwesome return new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = FontAwesome.fa_refresh, Icon = FontAwesome.fa_refresh,
TextSize = size, Size = new Vector2(size),
Colour = colours.Blue, Colour = colours.Blue,
Shadow = false, Shadow = false,
UseFullGlyphHeight = false,
}; };
} }
} }
@ -61,21 +60,19 @@ namespace osu.Game.Online.Multiplayer
Spacing = new Vector2(2f), Spacing = new Vector2(2f),
Children = new[] Children = new[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_refresh, Icon = FontAwesome.fa_refresh,
TextSize = size * 0.75f, Size = new Vector2(size * 0.75f),
Colour = colours.Blue, Colour = colours.Blue,
Shadow = false, Shadow = false,
UseFullGlyphHeight = false,
}, },
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_refresh, Icon = FontAwesome.fa_refresh,
TextSize = size * 0.75f, Size = new Vector2(size * 0.75f),
Colour = colours.Pink, Colour = colours.Pink,
Shadow = false, Shadow = false,
UseFullGlyphHeight = false,
}, },
}, },
}; };

View File

@ -28,7 +28,7 @@ namespace osu.Game.Overlays.Chat
private readonly Bindable<bool> joinedBind = new Bindable<bool>(); private readonly Bindable<bool> joinedBind = new Bindable<bool>();
private readonly OsuSpriteText name; private readonly OsuSpriteText name;
private readonly OsuSpriteText topic; private readonly OsuSpriteText topic;
private readonly TextAwesome joinedCheckmark; private readonly SpriteIcon joinedCheckmark;
private Color4 joinedColour; private Color4 joinedColour;
private Color4 topicColour; private Color4 topicColour;
@ -68,12 +68,12 @@ namespace osu.Game.Overlays.Chat
{ {
Children = new[] Children = new[]
{ {
joinedCheckmark = new TextAwesome joinedCheckmark = new SpriteIcon
{ {
Anchor = Anchor.TopRight, Anchor = Anchor.TopRight,
Origin = Anchor.TopRight, Origin = Anchor.TopRight,
Icon = FontAwesome.fa_check_circle, Icon = FontAwesome.fa_check_circle,
TextSize = text_size, Size = new Vector2(text_size),
Shadow = false, Shadow = false,
Margin = new MarginPadding { Right = 10f }, Margin = new MarginPadding { Right = 10f },
Alpha = 0f, Alpha = 0f,
@ -121,10 +121,10 @@ namespace osu.Game.Overlays.Chat
Spacing = new Vector2(3f, 0f), Spacing = new Vector2(3f, 0f),
Children = new Drawable[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_user, Icon = FontAwesome.fa_user,
TextSize = text_size - 2, Size = new Vector2(text_size - 2),
Shadow = false, Shadow = false,
Margin = new MarginPadding { Top = 1 }, Margin = new MarginPadding { Top = 1 },
}, },

View File

@ -35,13 +35,13 @@ namespace osu.Game.Overlays.Chat
TabContainer.Spacing = new Vector2(-shear_width, 0); TabContainer.Spacing = new Vector2(-shear_width, 0);
TabContainer.Masking = false; TabContainer.Masking = false;
AddInternal(new TextAwesome AddInternal(new SpriteIcon
{ {
Icon = FontAwesome.fa_comments, Icon = FontAwesome.fa_comments,
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
TextSize = 20, Size = new Vector2(20),
Padding = new MarginPadding(10), Margin = new MarginPadding(10),
}); });
AddTabItem(selectorTab = new ChannelTabItem.ChannelSelectorTabItem(new Channel { Name = "+" })); AddTabItem(selectorTab = new ChannelTabItem.ChannelSelectorTabItem(new Channel { Name = "+" }));
@ -72,7 +72,7 @@ namespace osu.Game.Overlays.Chat
private readonly SpriteText textBold; private readonly SpriteText textBold;
private readonly Box box; private readonly Box box;
private readonly Box highlightBox; private readonly Box highlightBox;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private void updateState() private void updateState()
{ {
@ -176,7 +176,7 @@ namespace osu.Game.Overlays.Chat
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Icon = FontAwesome.fa_hashtag, Icon = FontAwesome.fa_hashtag,
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
@ -184,7 +184,7 @@ namespace osu.Game.Overlays.Chat
Colour = Color4.Black, Colour = Color4.Black,
X = -10, X = -10,
Alpha = 0.2f, Alpha = 0.2f,
TextSize = ChatOverlay.TAB_AREA_HEIGHT, Size = new Vector2(ChatOverlay.TAB_AREA_HEIGHT),
}, },
text = new OsuSpriteText text = new OsuSpriteText
{ {

View File

@ -30,14 +30,14 @@ namespace osu.Game.Overlays.Dialog
private readonly Container content; private readonly Container content;
private readonly Container ring; private readonly Container ring;
private readonly FillFlowContainer<PopupDialogButton> buttonsContainer; private readonly FillFlowContainer<PopupDialogButton> buttonsContainer;
private readonly TextAwesome iconText; private readonly SpriteIcon icon;
private readonly SpriteText header; private readonly SpriteText header;
private readonly SpriteText body; private readonly SpriteText body;
public FontAwesome Icon public FontAwesome Icon
{ {
get { return iconText.Icon; } get { return icon.Icon; }
set { iconText.Icon = value; } set { icon.Icon = value; }
} }
public string HeaderText public string HeaderText
@ -205,12 +205,12 @@ namespace osu.Game.Overlays.Dialog
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = Color4.Black.Opacity(0), Colour = Color4.Black.Opacity(0),
}, },
iconText = new TextAwesome icon = new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Icon = FontAwesome.fa_close, Icon = FontAwesome.fa_close,
TextSize = 50, Size = new Vector2(50),
}, },
}, },
}, },

View File

@ -152,18 +152,17 @@ namespace osu.Game.Overlays.Direct
private class DownloadButton : OsuClickableContainer private class DownloadButton : OsuClickableContainer
{ {
private readonly TextAwesome icon; private readonly SpriteIcon icon;
public DownloadButton() public DownloadButton()
{ {
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
UseFullGlyphHeight = false, Size = new Vector2(30),
TextSize = 30,
Icon = FontAwesome.fa_osu_chevron_down_o, Icon = FontAwesome.fa_osu_chevron_down_o,
}, },
}; };

View File

@ -75,11 +75,11 @@ namespace osu.Game.Overlays.Direct
{ {
Font = @"Exo2.0-SemiBoldItalic", Font = @"Exo2.0-SemiBoldItalic",
}, },
new TextAwesome new SpriteIcon
{ {
Icon = icon, Icon = icon,
Shadow = true, Shadow = true,
TextSize = 14, Size = new Vector2(14),
Margin = new MarginPadding { Top = 1 }, Margin = new MarginPadding { Top = 1 },
}, },
}; };

View File

@ -47,7 +47,11 @@ namespace osu.Game.Overlays.Direct
private class RulesetToggleButton : OsuClickableContainer private class RulesetToggleButton : OsuClickableContainer
{ {
private readonly TextAwesome icon; private Drawable icon
{
get { return iconContainer.Icon; }
set { iconContainer.Icon = value; }
}
private RulesetInfo ruleset; private RulesetInfo ruleset;
public RulesetInfo Ruleset public RulesetInfo Ruleset
@ -56,15 +60,17 @@ namespace osu.Game.Overlays.Direct
set set
{ {
ruleset = value; ruleset = value;
icon.Icon = Ruleset.CreateInstance().Icon; icon = Ruleset.CreateInstance().CreateIcon();
} }
} }
private readonly Bindable<RulesetInfo> bindable; private readonly Bindable<RulesetInfo> bindable;
private readonly ConstrainedIconContainer iconContainer;
private void Bindable_ValueChanged(RulesetInfo obj) private void Bindable_ValueChanged(RulesetInfo obj)
{ {
icon.FadeTo(Ruleset.ID == obj?.ID ? 1f : 0.5f, 100); iconContainer.FadeTo(Ruleset.ID == obj?.ID ? 1f : 0.5f, 100);
} }
public RulesetToggleButton(Bindable<RulesetInfo> bindable, RulesetInfo ruleset) public RulesetToggleButton(Bindable<RulesetInfo> bindable, RulesetInfo ruleset)
@ -74,11 +80,11 @@ namespace osu.Game.Overlays.Direct
Children = new[] Children = new[]
{ {
icon = new TextAwesome iconContainer = new ConstrainedIconContainer
{ {
Origin = Anchor.TopLeft, Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft, Anchor = Anchor.TopLeft,
TextSize = 32, Size = new Vector2(32),
} }
}; };

View File

@ -36,7 +36,7 @@ namespace osu.Game.Overlays.Music
{ {
CornerRadius = 5; CornerRadius = 5;
Height = 30; Height = 30;
Icon.TextSize = 14; Icon.Size = new Vector2(14);
Icon.Margin = new MarginPadding(0); Icon.Margin = new MarginPadding(0);
Foreground.Padding = new MarginPadding { Top = 4, Bottom = 4, Left = 10, Right = 10 }; Foreground.Padding = new MarginPadding { Top = 4, Bottom = 4, Left = 10, Right = 10 };
EdgeEffect = new EdgeEffectParameters EdgeEffect = new EdgeEffectParameters

View File

@ -12,6 +12,7 @@ using osu.Framework.Localisation;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Graphics.Containers; using osu.Game.Graphics.Containers;
using OpenTK;
namespace osu.Game.Overlays.Music namespace osu.Game.Overlays.Music
{ {
@ -22,7 +23,7 @@ namespace osu.Game.Overlays.Music
private Color4 hoverColour; private Color4 hoverColour;
private Color4 artistColour; private Color4 artistColour;
private TextAwesome handle; private SpriteIcon handle;
private TextFlowContainer text; private TextFlowContainer text;
private IEnumerable<SpriteText> titleSprites; private IEnumerable<SpriteText> titleSprites;
private UnicodeBindableString titleBind; private UnicodeBindableString titleBind;
@ -67,16 +68,15 @@ namespace osu.Game.Overlays.Music
Children = new Drawable[] Children = new Drawable[]
{ {
handle = new TextAwesome handle = new SpriteIcon
{ {
Anchor = Anchor.TopLeft, Anchor = Anchor.TopLeft,
Origin = Anchor.TopLeft, Origin = Anchor.TopLeft,
TextSize = 12, Size = new Vector2(12),
Colour = colours.Gray5, Colour = colours.Gray5,
Icon = FontAwesome.fa_bars, Icon = FontAwesome.fa_bars,
Alpha = 0f, Alpha = 0f,
Margin = new MarginPadding { Left = 5 }, Margin = new MarginPadding { Left = 5, Top = 2 },
Padding = new MarginPadding { Top = 2 },
}, },
text = new OsuTextFlowContainer text = new OsuTextFlowContainer
{ {

View File

@ -165,12 +165,12 @@ namespace osu.Game.Overlays.Notifications
Children = new[] Children = new[]
{ {
new TextAwesome new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = FontAwesome.fa_times_circle, Icon = FontAwesome.fa_times_circle,
TextSize = 20 Size = new Vector2(20),
} }
}; };
} }

View File

@ -8,6 +8,7 @@ using osu.Framework.Graphics.Shapes;
using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Sprites;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Graphics.Sprites; using osu.Game.Graphics.Sprites;
using OpenTK;
namespace osu.Game.Overlays.Notifications namespace osu.Game.Overlays.Notifications
{ {
@ -36,7 +37,7 @@ namespace osu.Game.Overlays.Notifications
} }
private readonly SpriteText textDrawable; private readonly SpriteText textDrawable;
private readonly TextAwesome iconDrawable; private readonly SpriteIcon iconDrawable;
protected Box IconBackgound; protected Box IconBackgound;
@ -49,12 +50,12 @@ namespace osu.Game.Overlays.Notifications
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = ColourInfo.GradientVertical(OsuColour.Gray(0.2f), OsuColour.Gray(0.6f)) Colour = ColourInfo.GradientVertical(OsuColour.Gray(0.2f), OsuColour.Gray(0.6f))
}, },
iconDrawable = new TextAwesome iconDrawable = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = icon, Icon = icon,
TextSize = 20 Size = new Vector2(20),
} }
}); });

View File

@ -110,12 +110,12 @@ namespace osu.Game.Overlays.Profile
Alpha = 0, Alpha = 0,
AlwaysPresent = true AlwaysPresent = true
}, },
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_heart, Icon = FontAwesome.fa_heart,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = 12 Size = new Vector2(12),
} }
} }
}, },

View File

@ -55,7 +55,7 @@ namespace osu.Game.Overlays.SearchableList
private class DisplayStyleToggleButton : OsuClickableContainer private class DisplayStyleToggleButton : OsuClickableContainer
{ {
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private readonly PanelDisplayStyle style; private readonly PanelDisplayStyle style;
private readonly Bindable<PanelDisplayStyle> bindable; private readonly Bindable<PanelDisplayStyle> bindable;
@ -67,13 +67,12 @@ namespace osu.Game.Overlays.SearchableList
Children = new Drawable[] Children = new Drawable[]
{ {
this.icon = new TextAwesome this.icon = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = icon, Icon = icon,
TextSize = 18, Size = new Vector2(18),
UseFullGlyphHeight = false,
Alpha = 0.5f, Alpha = 0.5f,
}, },
}; };

View File

@ -55,9 +55,9 @@ namespace osu.Game.Overlays.SearchableList
Spacing = new Vector2(10f, 0f), Spacing = new Vector2(10f, 0f),
Children = new[] Children = new[]
{ {
new TextAwesome new SpriteIcon
{ {
TextSize = 25, Size = new Vector2(25),
Icon = Icon, Icon = Icon,
}, },
CreateHeaderText(), CreateHeaderText(),

View File

@ -6,6 +6,7 @@ using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.UserInterface; using osu.Framework.Graphics.UserInterface;
using osu.Game.Graphics.UserInterface; using osu.Game.Graphics.UserInterface;
using OpenTK;
namespace osu.Game.Overlays.SearchableList namespace osu.Game.Overlays.SearchableList
{ {
@ -19,7 +20,7 @@ namespace osu.Game.Overlays.SearchableList
public SlimDropdownHeader() public SlimDropdownHeader()
{ {
Height = 25; Height = 25;
Icon.TextSize = 16; Icon.Size = new Vector2(16);
Foreground.Padding = new MarginPadding { Top = 4, Bottom = 4, Left = 8, Right = 4 }; Foreground.Padding = new MarginPadding { Top = 4, Bottom = 4, Left = 8, Right = 4 };
} }

View File

@ -286,7 +286,7 @@ namespace osu.Game.Overlays.Settings.Sections.General
{ {
public const float LABEL_LEFT_MARGIN = 20; public const float LABEL_LEFT_MARGIN = 20;
private readonly TextAwesome statusIcon; private readonly SpriteIcon statusIcon;
public Color4 StatusColour public Color4 StatusColour
{ {
set set
@ -308,15 +308,15 @@ namespace osu.Game.Overlays.Settings.Sections.General
Radius = 4, Radius = 4,
}; };
Icon.TextSize = 14; Icon.Size = new Vector2(14);
Icon.Margin = new MarginPadding(0); Icon.Margin = new MarginPadding(0);
Foreground.Add(statusIcon = new TextAwesome Foreground.Add(statusIcon = new SpriteIcon
{ {
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
Icon = FontAwesome.fa_circle_o, Icon = FontAwesome.fa_circle_o,
TextSize = 14, Size = new Vector2(14),
}); });
Text.Margin = new MarginPadding { Left = LABEL_LEFT_MARGIN }; Text.Margin = new MarginPadding { Left = LABEL_LEFT_MARGIN };

View File

@ -6,6 +6,7 @@ using osu.Framework.Allocation;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Graphics.Containers;
using osu.Game.Graphics.Sprites; using osu.Game.Graphics.Sprites;
using osu.Game.Rulesets; using osu.Game.Rulesets;
using OpenTK; using OpenTK;
@ -27,12 +28,14 @@ namespace osu.Game.Overlays.Settings
foreach (var ruleset in rulesets.AllRulesets) foreach (var ruleset in rulesets.AllRulesets)
{ {
modes.Add(new TextAwesome var icon = new ConstrainedIconContainer
{ {
Icon = ruleset.CreateInstance().Icon, Icon = ruleset.CreateInstance().CreateIcon(),
Colour = Color4.Gray, Colour = Color4.Gray,
TextSize = 20 Size = new Vector2(20),
}); };
modes.Add(icon);
} }
Children = new Drawable[] Children = new Drawable[]

View File

@ -17,7 +17,7 @@ namespace osu.Game.Overlays.Settings
{ {
public class SidebarButton : Container public class SidebarButton : Container
{ {
private readonly TextAwesome drawableIcon; private readonly SpriteIcon drawableIcon;
private readonly SpriteText headerText; private readonly SpriteText headerText;
private readonly Box backgroundBox; private readonly Box backgroundBox;
private readonly Box selectionIndicator; private readonly Box selectionIndicator;
@ -77,7 +77,7 @@ namespace osu.Game.Overlays.Settings
Width = Sidebar.DEFAULT_WIDTH, Width = Sidebar.DEFAULT_WIDTH,
RelativeSizeAxes = Axes.Y, RelativeSizeAxes = Axes.Y,
Colour = OsuColour.Gray(0.6f), Colour = OsuColour.Gray(0.6f),
Children = new[] Children = new Drawable[]
{ {
headerText = new OsuSpriteText headerText = new OsuSpriteText
{ {
@ -85,11 +85,11 @@ namespace osu.Game.Overlays.Settings
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
}, },
drawableIcon = new TextAwesome drawableIcon = new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = 20 Size = new Vector2(20),
}, },
} }
}, },

View File

@ -20,10 +20,21 @@ namespace osu.Game.Overlays.Toolbar
{ {
public const float WIDTH = Toolbar.HEIGHT * 1.4f; public const float WIDTH = Toolbar.HEIGHT * 1.4f;
public void SetIcon(Drawable icon)
{
IconContainer.Icon = icon;
IconContainer.Show();
}
public void SetIcon(FontAwesome icon) => SetIcon(new SpriteIcon
{
Size = new Vector2(20),
Icon = icon
});
public FontAwesome Icon public FontAwesome Icon
{ {
get { return DrawableIcon.Icon; } set { SetIcon(value); }
set { DrawableIcon.Icon = value; }
} }
public string Text public string Text
@ -55,7 +66,7 @@ namespace osu.Game.Overlays.Toolbar
protected virtual Anchor TooltipAnchor => Anchor.TopLeft; protected virtual Anchor TooltipAnchor => Anchor.TopLeft;
protected TextAwesome DrawableIcon; protected ConstrainedIconContainer IconContainer;
protected SpriteText DrawableText; protected SpriteText DrawableText;
protected Box HoverBackground; protected Box HoverBackground;
private readonly FillFlowContainer tooltipContainer; private readonly FillFlowContainer tooltipContainer;
@ -88,11 +99,12 @@ namespace osu.Game.Overlays.Toolbar
AutoSizeAxes = Axes.X, AutoSizeAxes = Axes.X,
Children = new Drawable[] Children = new Drawable[]
{ {
DrawableIcon = new TextAwesome IconContainer = new ConstrainedIconContainer
{ {
Anchor = Anchor.Centre, Anchor = Anchor.CentreLeft,
Origin = Anchor.Centre, Origin = Anchor.CentreLeft,
TextSize = 20 Size = new Vector2(20),
Alpha = 0,
}, },
DrawableText = new OsuSpriteText DrawableText = new OsuSpriteText
{ {

View File

@ -10,7 +10,7 @@ namespace osu.Game.Overlays.Toolbar
{ {
public ToolbarChatButton() public ToolbarChatButton()
{ {
Icon = FontAwesome.fa_comments; SetIcon(FontAwesome.fa_comments);
} }
[BackgroundDependencyLoader] [BackgroundDependencyLoader]

View File

@ -21,7 +21,7 @@ namespace osu.Game.Overlays.Toolbar
TooltipMain = rInstance.Description; TooltipMain = rInstance.Description;
TooltipSub = $"Play some {rInstance.Description}"; TooltipSub = $"Play some {rInstance.Description}";
Icon = rInstance.Icon; SetIcon(rInstance.CreateIcon());
} }
} }
@ -31,9 +31,8 @@ namespace osu.Game.Overlays.Toolbar
{ {
if (value) if (value)
{ {
DrawableIcon.Colour = Color4.White; IconContainer.Colour = Color4.White;
DrawableIcon.Masking = true; IconContainer.EdgeEffect = new EdgeEffectParameters
DrawableIcon.EdgeEffect = new EdgeEffectParameters
{ {
Type = EdgeEffectType.Glow, Type = EdgeEffectType.Glow,
Colour = new Color4(255, 194, 224, 100), Colour = new Color4(255, 194, 224, 100),
@ -43,8 +42,8 @@ namespace osu.Game.Overlays.Toolbar
} }
else else
{ {
DrawableIcon.Masking = false; IconContainer.Colour = new Color4(255, 194, 224, 255);
DrawableIcon.Colour = new Color4(255, 194, 224, 255); IconContainer.EdgeEffect = new EdgeEffectParameters();
} }
} }
} }
@ -52,7 +51,7 @@ namespace osu.Game.Overlays.Toolbar
protected override void LoadComplete() protected override void LoadComplete()
{ {
base.LoadComplete(); base.LoadComplete();
DrawableIcon.TextSize *= 1.4f; IconContainer.Scale *= 1.4f;
} }
} }
} }

View File

@ -7,6 +7,7 @@ using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.UI; using osu.Game.Rulesets.UI;
using osu.Game.Screens.Play; using osu.Game.Screens.Play;
using System.Collections.Generic; using System.Collections.Generic;
using osu.Framework.Graphics;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
using osu.Game.Overlays.Settings; using osu.Game.Overlays.Settings;
@ -31,7 +32,7 @@ namespace osu.Game.Rulesets
public abstract ScoreProcessor CreateScoreProcessor(); public abstract ScoreProcessor CreateScoreProcessor();
public virtual FontAwesome Icon => FontAwesome.fa_question_circle; public virtual Drawable CreateIcon() => new SpriteIcon { Icon = FontAwesome.fa_question_circle };
public abstract string Description { get; } public abstract string Description { get; }

View File

@ -8,13 +8,14 @@ using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Game.Rulesets.Mods; using osu.Game.Rulesets.Mods;
using OpenTK;
namespace osu.Game.Rulesets.UI namespace osu.Game.Rulesets.UI
{ {
public class ModIcon : Container public class ModIcon : Container
{ {
private readonly TextAwesome modIcon; private readonly SpriteIcon modIcon;
private readonly TextAwesome background; private readonly SpriteIcon background;
private const float icon_size = 80; private const float icon_size = 80;
@ -34,20 +35,20 @@ namespace osu.Game.Rulesets.UI
Children = new Drawable[] Children = new Drawable[]
{ {
background = new TextAwesome background = new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
TextSize = icon_size, Size = new Vector2(icon_size),
Icon = FontAwesome.fa_osu_mod_bg, Icon = FontAwesome.fa_osu_mod_bg,
Shadow = true, Shadow = true,
}, },
modIcon = new TextAwesome modIcon = new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Colour = OsuColour.Gray(84), Colour = OsuColour.Gray(84),
TextSize = icon_size - 35, Size = new Vector2(icon_size - 35),
Icon = mod.Icon Icon = mod.Icon
}, },
}; };

View File

@ -31,7 +31,7 @@ namespace osu.Game.Screens.Menu
private readonly Container iconText; private readonly Container iconText;
private readonly Container box; private readonly Container box;
private readonly Box boxHoverLayer; private readonly Box boxHoverLayer;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private readonly string sampleName; private readonly string sampleName;
private readonly Action clickAction; private readonly Action clickAction;
private readonly Key triggerKey; private readonly Key triggerKey;
@ -95,12 +95,12 @@ namespace osu.Game.Screens.Menu
Origin = Anchor.Centre, Origin = Anchor.Centre,
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Shadow = true, Shadow = true,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
TextSize = 30, Size = new Vector2(30),
Position = new Vector2(0, 0), Position = new Vector2(0, 0),
Icon = symbol Icon = symbol
}, },

View File

@ -15,7 +15,7 @@ namespace osu.Game.Screens.Menu
internal class Disclaimer : OsuScreen internal class Disclaimer : OsuScreen
{ {
private Intro intro; private Intro intro;
private readonly TextAwesome icon; private readonly SpriteIcon icon;
private Color4 iconColour; private Color4 iconColour;
internal override bool ShowOverlays => false; internal override bool ShowOverlays => false;
@ -37,12 +37,12 @@ namespace osu.Game.Screens.Menu
Spacing = new Vector2(0, 2), Spacing = new Vector2(0, 2),
Children = new Drawable[] Children = new Drawable[]
{ {
icon = new TextAwesome icon = new SpriteIcon
{ {
Anchor = Anchor.TopCentre, Anchor = Anchor.TopCentre,
Origin = Anchor.TopCentre, Origin = Anchor.TopCentre,
Icon = FontAwesome.fa_warning, Icon = FontAwesome.fa_warning,
TextSize = 30, Size = new Vector2(30),
}, },
new OsuSpriteText new OsuSpriteText
{ {

View File

@ -227,9 +227,9 @@ namespace osu.Game.Screens.Play
Direction = FillDirection.Horizontal, Direction = FillDirection.Horizontal,
Children = new[] Children = new[]
{ {
new TextAwesome { Icon = FontAwesome.fa_chevron_right }, new SpriteIcon { Icon = FontAwesome.fa_chevron_right },
new TextAwesome { Icon = FontAwesome.fa_chevron_right }, new SpriteIcon { Icon = FontAwesome.fa_chevron_right },
new TextAwesome { Icon = FontAwesome.fa_chevron_right }, new SpriteIcon { Icon = FontAwesome.fa_chevron_right },
} }
}, },
new OsuSpriteText new OsuSpriteText

View File

@ -78,14 +78,14 @@ namespace osu.Game.Screens.Ranking
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = Color4.Transparent, Colour = Color4.Transparent,
}, },
new TextAwesome new SpriteIcon
{ {
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Shadow = false, Shadow = false,
Colour = OsuColour.Gray(0.95f), Colour = OsuColour.Gray(0.95f),
Icon = icon, Icon = icon,
TextSize = 20, Size = new Vector2(20),
} }
} }
} }

View File

@ -108,14 +108,14 @@ namespace osu.Game.Screens
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Direction = FillDirection.Vertical, Direction = FillDirection.Vertical,
Children = new[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_universal_access, Icon = FontAwesome.fa_universal_access,
Anchor = Anchor.TopCentre, Anchor = Anchor.TopCentre,
Origin = Anchor.TopCentre, Origin = Anchor.TopCentre,
TextSize = 50, Size = new Vector2(50),
}, },
new OsuSpriteText new OsuSpriteText
{ {

View File

@ -247,21 +247,21 @@ namespace osu.Game.Screens.Select
AutoSizeAxes = Axes.Both; AutoSizeAxes = Axes.Both;
Children = new Drawable[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Icon = FontAwesome.fa_square, Icon = FontAwesome.fa_square,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Colour = new Color4(68, 17, 136, 255), Colour = new Color4(68, 17, 136, 255),
Rotation = 45, Rotation = 45,
TextSize = 20 Size = new Vector2(20),
}, },
new TextAwesome new SpriteIcon
{ {
Icon = statistic.Icon, Icon = statistic.Icon,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Colour = new Color4(255, 221, 85, 255), Colour = new Color4(255, 221, 85, 255),
Scale = new Vector2(0.8f), Scale = new Vector2(0.8f),
TextSize = 20 Size = new Vector2(20),
}, },
new OsuSpriteText new OsuSpriteText
{ {

View File

@ -121,7 +121,7 @@ namespace osu.Game.Screens.Select
//{ //{
// Font = @"Exo2.0-Bold", // Font = @"Exo2.0-Bold",
// Text = "Sort results by", // Text = "Sort results by",
// TextSize = 14, // Size = 14,
// Margin = new MarginPadding // Margin = new MarginPadding
// { // {
// Top = 5, // Top = 5,

View File

@ -334,25 +334,23 @@ namespace osu.Game.Screens.Select.Leaderboards
Children = new[] Children = new[]
{ {
new TextAwesome new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Icon = FontAwesome.fa_osu_mod_bg, Icon = FontAwesome.fa_osu_mod_bg,
Colour = colour, Colour = colour,
Shadow = true, Shadow = true,
TextSize = 30, Size = new Vector2(30),
UseFullGlyphHeight = false,
}, },
new TextAwesome new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Icon = icon, Icon = icon,
Colour = OsuColour.Gray(84), Colour = OsuColour.Gray(84),
TextSize = 18, Size = new Vector2(18),
Position = new Vector2(0f, 2f), Position = new Vector2(0f, 2f),
UseFullGlyphHeight = false,
}, },
}; };
} }
@ -369,7 +367,7 @@ namespace osu.Game.Screens.Select.Leaderboards
Children = new Drawable[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = FontAwesome.fa_square, Icon = FontAwesome.fa_square,
@ -377,7 +375,7 @@ namespace osu.Game.Screens.Select.Leaderboards
Rotation = 45, Rotation = 45,
Shadow = true, Shadow = true,
}, },
new TextAwesome new SpriteIcon
{ {
Origin = Anchor.Centre, Origin = Anchor.Centre,
Icon = icon, Icon = icon,

View File

@ -21,7 +21,7 @@ namespace osu.Game.Screens.Select.Options
private readonly Box background; private readonly Box background;
private readonly Box flash; private readonly Box flash;
private readonly TextAwesome iconText; private readonly SpriteIcon iconText;
private readonly OsuSpriteText firstLine; private readonly OsuSpriteText firstLine;
private readonly OsuSpriteText secondLine; private readonly OsuSpriteText secondLine;
private readonly Container box; private readonly Container box;
@ -134,11 +134,11 @@ namespace osu.Game.Screens.Select.Options
Direction = FillDirection.Vertical, Direction = FillDirection.Vertical,
Children = new Drawable[] Children = new Drawable[]
{ {
iconText = new TextAwesome iconText = new SpriteIcon
{ {
Origin = Anchor.TopCentre, Origin = Anchor.TopCentre,
Anchor = Anchor.TopCentre, Anchor = Anchor.TopCentre,
TextSize = 30, Size = new Vector2(30),
Shadow = true, Shadow = true,
Icon = FontAwesome.fa_close, Icon = FontAwesome.fa_close,
Margin = new MarginPadding Margin = new MarginPadding

View File

@ -142,15 +142,15 @@ namespace osu.Game.Users
Origin = Anchor.Centre, Origin = Anchor.Centre,
AutoSizeAxes = Axes.Both, AutoSizeAxes = Axes.Both,
Spacing = new Vector2(5f, 0f), Spacing = new Vector2(5f, 0f),
Children = new[] Children = new Drawable[]
{ {
new TextAwesome new SpriteIcon
{ {
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.CentreLeft,
Icon = FontAwesome.fa_circle_o, Icon = FontAwesome.fa_circle_o,
Shadow = true, Shadow = true,
TextSize = 14, Size = new Vector2(14),
}, },
statusMessage = new OsuSpriteText statusMessage = new OsuSpriteText
{ {

View File

@ -116,6 +116,7 @@
<Compile Include="Overlays\Profile\RankChart.cs" /> <Compile Include="Overlays\Profile\RankChart.cs" />
<Compile Include="Overlays\Profile\Sections\RanksSection.cs" /> <Compile Include="Overlays\Profile\Sections\RanksSection.cs" />
<Compile Include="Overlays\Profile\Sections\RecentSection.cs" /> <Compile Include="Overlays\Profile\Sections\RecentSection.cs" />
<Compile Include="Graphics\Containers\ConstrainedIconContainer.cs" />
<Compile Include="Users\UserCoverBackground.cs" /> <Compile Include="Users\UserCoverBackground.cs" />
<Compile Include="Overlays\UserProfileOverlay.cs" /> <Compile Include="Overlays\UserProfileOverlay.cs" />
<Compile Include="Overlays\Profile\ProfileHeader.cs" /> <Compile Include="Overlays\Profile\ProfileHeader.cs" />
@ -349,7 +350,7 @@
<Compile Include="Graphics\Containers\ParallaxContainer.cs" /> <Compile Include="Graphics\Containers\ParallaxContainer.cs" />
<Compile Include="Graphics\Cursor\MenuCursor.cs" /> <Compile Include="Graphics\Cursor\MenuCursor.cs" />
<Compile Include="Graphics\Processing\RatioAdjust.cs" /> <Compile Include="Graphics\Processing\RatioAdjust.cs" />
<Compile Include="Graphics\TextAwesome.cs" /> <Compile Include="Graphics\SpriteIcon.cs" />
<Compile Include="Screens\Play\KeyCounter.cs" /> <Compile Include="Screens\Play\KeyCounter.cs" />
<Compile Include="Screens\Play\KeyCounterKeyboard.cs" /> <Compile Include="Screens\Play\KeyCounterKeyboard.cs" />
<Compile Include="Screens\Play\KeyCounterCollection.cs" /> <Compile Include="Screens\Play\KeyCounterCollection.cs" />