1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 16:12:57 +08:00

Merged ExtendableButton and BackButton

This commit is contained in:
stanriders 2016-11-27 05:48:31 +03:00
parent af57984d5c
commit ba18c9a309
5 changed files with 81 additions and 140 deletions

@ -1 +1 @@
Subproject commit ea56eab4a2bb4c9723052586ed30c687898fecb0 Subproject commit 24af3b161da9447b678edd8ec32193df54f71e3b

View File

@ -4,52 +4,91 @@
using OpenTK; using OpenTK;
using OpenTK.Graphics; using OpenTK.Graphics;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Transformations; using osu.Framework.Graphics.Transformations;
using osu.Framework.Input; using osu.Framework.Input;
namespace osu.Game.Graphics.UserInterface namespace osu.Game.Graphics.UserInterface
{ {
// Basic back button as it was on stable (kinda). No skinning possible for now // Basic back button as it was on stable (kinda). No skinning possible for now
class BackButton : ExtendableButton class BackButton : ClickableContainer
{ {
private TextAwesome icon; private TextAwesome icon;
private Vector2 iconPos = new Vector2(20, 0); private Vector2 iconPos;
private Box bgBox;
private Box textBox;
private Container textContainer;
private SpriteText spriteText;
public Vector2 ExtendLength;
public Vector2 InitialExtendLength;
private const double transformTime = 300.0;
public BackButton() public BackButton()
{ {
InitialExtendLenght = new Vector2(40, 0); // [ should be set or should be relative?
ExtendLenght = new Vector2(60, 0); InitialExtendLength = new Vector2(40, 0);
ExtendLength = new Vector2(60, 0);
iconPos = new Vector2(20, 0);
RelativeSizeAxes = Axes.Y;
Width = 80; Width = 80;
//Height = 40; // should be set or should be relative? //Height = 40;
// ] should be set or should be relative?
Text = @"Back";
BGColour = new Color4(195, 40, 140, 255);
Colour = new Color4(238, 51, 153, 255);
Children = new Drawable[] Children = new Drawable[]
{ {
bgBox = new Box
{
RelativeSizeAxes = Axes.Both,
Colour = new Color4(195, 40, 140, 255),
},
icon = new TextAwesome icon = new TextAwesome
{ {
Anchor = Anchor.CentreLeft, Anchor = Anchor.CentreLeft,
TextSize = 25, TextSize = 25,
Position = iconPos, Position = iconPos,
Icon = FontAwesome.fa_osu_left_o Icon = FontAwesome.fa_osu_left_o
},
textContainer = new Container
{
Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft,
RelativeSizeAxes = Axes.Both,
Position = Position + InitialExtendLength,
Children = new Drawable[]
{
textBox = new Box
{
Colour = new Color4(238, 51, 153, 255),
Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft,
RelativeSizeAxes = Axes.Both,
Shear = new Vector2(0.1f, 0),
EdgeSmoothness = new Vector2(1.5f, 0),
},
spriteText = new SpriteText
{
Origin = Anchor.Centre,
Anchor = Anchor.Centre,
Text = @"Back",
}
}
} }
}; };
// HACK: because it never uses InitialExtendLenght that we give to it on creation // HACK: because it never uses InitialExtendLength that we give to it on creation
textContainer.Position = Position + InitialExtendLenght; textContainer.Position = Position + InitialExtendLength;
} }
protected override bool OnHover(InputState state) protected override bool OnHover(InputState state)
{ {
bool result = base.OnHover(state);
icon.ClearTransformations(); icon.ClearTransformations();
textContainer.ClearTransformations();
icon.MoveToX(iconPos.X + 10, 150, EasingTypes.OutElastic); textContainer.MoveTo(Position + ExtendLength, transformTime, EasingTypes.OutElastic);
icon.MoveToX(iconPos.X + 10, transformTime, EasingTypes.OutElastic);
int duration = 0; //(int)(Game.Audio.BeatLength / 2); int duration = 0; //(int)(Game.Audio.BeatLength / 2);
if (duration == 0) duration = 250; if (duration == 0) duration = 250;
@ -69,15 +108,34 @@ namespace osu.Game.Graphics.UserInterface
LoopDelay = duration LoopDelay = duration
}); });
return result; return true;
} }
protected override void OnHoverLost(InputState state) protected override void OnHoverLost(InputState state)
{ {
icon.ClearTransformations(); icon.ClearTransformations();
icon.MoveToX(iconPos.X, 150, EasingTypes.OutElastic); textContainer.ClearTransformations();
base.OnHoverLost(state); textContainer.MoveTo(Position + InitialExtendLength, transformTime, EasingTypes.OutElastic);
icon.MoveToX(iconPos.X, transformTime, EasingTypes.OutElastic);
}
protected override bool OnClick(InputState state)
{
var flash = new Box
{
RelativeSizeAxes = RelativeSizeAxes
};
Add(flash);
flash.Colour = textBox.Colour;
flash.BlendingMode = BlendingMode.Additive;
flash.Alpha = 0.3f;
flash.FadeOutFromOne(200);
flash.Expire();
return base.OnClick(state);
} }
} }
} }

View File

@ -1,117 +0,0 @@
// Copyright (c) 2007-2016 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu-framework/master/LICENCE
using osu.Framework.Input;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Transformations;
using OpenTK;
using OpenTK.Graphics;
namespace osu.Game.Graphics.UserInterface
{
public class ExtendableButton : ClickableContainer
{
public Color4 BGColour
{
get { return bgBox.Colour; }
set { bgBox.Colour = value; }
}
public new Color4 Colour
{
get { return textBox.Colour; }
set { textBox.Colour = value; }
}
public new Vector2 Shear
{
get { return textBox.Shear; }
set { textBox.Shear = value; }
}
public string Text
{
get { return spriteText?.Text; }
set
{
if (spriteText != null)
spriteText.Text = value;
}
}
private Box bgBox;
private Box textBox;
public Container textContainer;
private SpriteText spriteText;
public Vector2 ExtendLenght = new Vector2(80,0); // this one can be defaulted
public Vector2 InitialExtendLenght/* = new Vector2(40, 0)*/; // but this one unfortunately cant
public ExtendableButton(float initialExtendLenghtX = 20, float initialExtendLenghtY = 0)
{
InitialExtendLenght = new Vector2(initialExtendLenghtX, initialExtendLenghtY); // because it just wont use defined settings when creating
Children = new Drawable[]
{
bgBox = new Box
{
RelativeSizeAxes = Axes.Both,
},
textContainer = new Container
{
Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft,
RelativeSizeAxes = Axes.Both,
Position = Position + InitialExtendLenght,
Children = new Drawable[]
{
textBox = new Box
{
Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft,
RelativeSizeAxes = Axes.Both,
Shear = new Vector2(0.1f, 0), // should be relative?
EdgeSmoothness = new Vector2(1, 1), // should be based on which side is being cut?
},
spriteText = new SpriteText
{
Origin = Anchor.Centre,
Anchor = Anchor.Centre,
}
}
}
};
}
protected override bool OnHover(InputState state)
{
textContainer.ClearTransformations();
textContainer.MoveTo(Position + ExtendLenght, 150, EasingTypes.OutElastic);
return base.OnHover(state);
}
protected override void OnHoverLost(InputState state)
{
base.OnHoverLost(state);
textContainer.ClearTransformations();
textContainer.MoveTo(Position + InitialExtendLenght, 150, EasingTypes.OutElastic);
}
protected override bool OnClick(InputState state)
{
var flash = new Box
{
RelativeSizeAxes = Axes.Both
};
Add(flash);
flash.Colour = textBox.Colour;
flash.BlendingMode = BlendingMode.Additive;
flash.Alpha = 0.3f;
flash.FadeOutFromOne(200);
flash.Expire();
return base.OnClick(state);
}
}
}

View File

@ -123,8 +123,9 @@ namespace osu.Game.Screens.Select
}, },
new BackButton new BackButton
{ {
Anchor = Anchor.CentreLeft, Anchor = Anchor.BottomLeft,
Origin = Anchor.CentreLeft, Origin = Anchor.BottomLeft,
RelativeSizeAxes = Axes.Y,
Action = () => Exit() Action = () => Exit()
}, },
new Button new Button

View File

@ -66,7 +66,6 @@
<Compile Include="Beatmaps\Drawables\BeatmapBackgroundSprite.cs" /> <Compile Include="Beatmaps\Drawables\BeatmapBackgroundSprite.cs" />
<Compile Include="Graphics\Cursor\CursorTrail.cs" /> <Compile Include="Graphics\Cursor\CursorTrail.cs" />
<Compile Include="Graphics\UserInterface\BackButton.cs" /> <Compile Include="Graphics\UserInterface\BackButton.cs" />
<Compile Include="Graphics\UserInterface\ExtendableButton.cs" />
<Compile Include="Modes\Objects\HitObjectParser.cs" /> <Compile Include="Modes\Objects\HitObjectParser.cs" />
<Compile Include="Overlays\DragBar.cs" /> <Compile Include="Overlays\DragBar.cs" />
<Compile Include="Overlays\MusicController.cs" /> <Compile Include="Overlays\MusicController.cs" />