1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-14 18:32:56 +08:00

Refactor2

This commit is contained in:
HoutarouOreki 2018-07-19 21:49:13 +02:00
parent bcd132e87f
commit a9299423cd
12 changed files with 36 additions and 74 deletions

View File

@ -63,8 +63,6 @@ namespace osu.Game.Input.Bindings
ToggleChat,
[Description("Toggle social overlay")]
ToggleSocial,
[Description("Toggle changelog")]
ToggleChangelog,
[Description("Reset input settings")]
ResetInputSettings,
[Description("Toggle toolbar")]

View File

@ -53,8 +53,6 @@ namespace osu.Game
private DialogOverlay dialogOverlay;
private ChangelogOverlay changelog;
private DirectOverlay direct;
private SocialOverlay social;
@ -112,8 +110,6 @@ namespace osu.Game
public void ToggleDirect() => direct.ToggleVisibility();
public void ToggleChangelog() => changelog.ToggleVisibility();
/// <summary>
/// Close all game-wide overlays.
/// </summary>
@ -285,7 +281,6 @@ namespace osu.Game
loadComponentSingleFile(screenshotManager, Add);
//overlay elements
loadComponentSingleFile(changelog = new ChangelogOverlay { Depth = -1 }, mainContent.Add);
loadComponentSingleFile(direct = new DirectOverlay { Depth = -1 }, mainContent.Add);
loadComponentSingleFile(social = new SocialOverlay { Depth = -1 }, mainContent.Add);
loadComponentSingleFile(chat = new ChatOverlay { Depth = -1 }, mainContent.Add);
@ -320,7 +315,6 @@ namespace osu.Game
dependencies.Cache(settings);
dependencies.Cache(onscreenDisplay);
dependencies.Cache(social);
dependencies.Cache(changelog);
dependencies.Cache(direct);
dependencies.Cache(chat);
dependencies.Cache(userProfile);
@ -355,7 +349,7 @@ namespace osu.Game
}
// ensure only one of these overlays are open at once.
var singleDisplayOverlays = new OverlayContainer[] { chat, social, direct, changelog };
var singleDisplayOverlays = new OverlayContainer[] { chat, social, direct };
overlays.AddRange(singleDisplayOverlays);
foreach (var overlay in singleDisplayOverlays)
@ -465,9 +459,6 @@ namespace osu.Game
case GlobalAction.ToggleSocial:
social.ToggleVisibility();
return true;
case GlobalAction.ToggleChangelog:
changelog.ToggleVisibility();
return true;
case GlobalAction.ResetInputSettings:
var sensitivity = frameworkConfig.GetBindable<double>(FrameworkSetting.CursorSensitivity);

View File

@ -10,6 +10,7 @@ using osu.Game.Graphics;
namespace osu.Game.Overlays.Changelog
{
// maybe look to osu.Game.Screens.Play.SquareGraph for reference later
// placeholder json file: https://api.myjson.com/bins/10ye8a
public class ChangelogChart : BufferedContainer
{
public ChangelogChart()

View File

@ -11,8 +11,13 @@ namespace osu.Game.Overlays.Changelog
public ChangelogContent()
{
RelativeSizeAxes = Axes.X;
//AutoSizeAxes = Axes.Y;
AutoSizeAxes = Axes.Y;
Direction = FillDirection.Vertical;
Padding = new MarginPadding
{
Left = 70,
Right = 70,
};
}
}
}

View File

@ -75,7 +75,8 @@ namespace osu.Game.Overlays.Changelog
{
Text = build.DisplayVersion,
TextSize = 28, // web: 24,
Colour = StreamColour.STABLE,
Font = @"Exo2.0-Light",
Colour = StreamColour.FromStreamName(build.UpdateStream.Name),
},
}
},
@ -90,7 +91,7 @@ namespace osu.Game.Overlays.Changelog
new SpriteText
{
// do we need .ToUniversalTime() here?
// also, this is a temporary solution to weekdays in >localized< date strings
// also, this should be a temporary solution to weekdays in >localized< date strings
Text = build.CreatedAt.Date.ToLongDateString().Replace(build.CreatedAt.ToString("dddd") + ", ", ""),
TextSize = 17, // web: 14,
Colour = OsuColour.FromHex(@"FD5"),

View File

@ -21,7 +21,7 @@ namespace osu.Game.Overlays.Changelog
{
protected Color4 Purple = new Color4(191, 4, 255, 255);
private readonly Sprite coverImage;
private readonly Sprite headerBadge; //50x50, margin-right: 20
private readonly Sprite headerBadge;
private readonly OsuSpriteText titleStream;
private readonly TextBadgePairListing listing;
private readonly TextBadgePairRelease releaseStream;
@ -46,10 +46,7 @@ namespace osu.Game.Overlays.Changelog
coverImage = new Sprite
{
RelativeSizeAxes = Axes.Both,
Size = new Vector2(1),
FillMode = FillMode.Fill,
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
},
new Container // this is the line badge-Changelog-Stream
{
@ -79,11 +76,11 @@ namespace osu.Game.Overlays.Changelog
// this box has 2 functions:
// - ensures the circle doesn't disappear on the X and Y edges
// - lessens the white "contamination" on the circle (due to smoothing)
// - gets rid of the white "contamination" on the circle (due to smoothing)
// (https://i.imgur.com/SMuvWBZ.png)
new Box
{
RelativeSizeAxes = Axes.Both,
Size = new Vector2(1),
Alpha = 0,
AlwaysPresent = true,
Colour = Purple,

View File

@ -14,42 +14,44 @@ namespace osu.Game.Overlays.Changelog
public class ChangelogStreams : Container
{
private const float container_height = 106.5f;
private const float container_margin_y = 20;
private const float container_margin_x = 85;
private const float padding_y = 20;
private const float padding_x = 85;
public Action OnSelection;
public APIChangelog SelectedRelease;
// not using SelectedRelease as a Bindable and then using .OnValueChange instead of OnSelection
// because it doesn't "refresh" the selection if the same stream is chosen
public readonly FillFlowContainer<StreamBadge> BadgesContainer;
public ChangelogStreams()
{
Height = container_height;
// this should actually be resizeable (https://streamable.com/yw2ug)
// if not, with small width:height ratio it cuts off right-most content
RelativeSizeAxes = Axes.X;
AutoSizeAxes = Axes.Y;
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
Size = new OpenTK.Vector2(1),
Colour = new Color4(32, 24, 35, 255),
},
BadgesContainer = new FillFlowContainer<StreamBadge>
{
Direction = FillDirection.Horizontal,
RelativeSizeAxes = Axes.Both,
Margin = new MarginPadding
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Padding = new MarginPadding
{
Top = container_margin_y,
Bottom = container_margin_y,
Left = container_margin_x,
Right = container_margin_x,
Top = padding_y,
Bottom = padding_y,
Left = padding_x,
Right = padding_x,
},
},
};
// ok, so this is probably not the best.
// will need to reflect on this.
// do we need the changelog to be updateable?
// how else can this be done?
BadgesContainer.OnUpdate = d =>
{
foreach (StreamBadge streamBadge in BadgesContainer.Children)

View File

@ -61,9 +61,8 @@ namespace osu.Game.Overlays.Changelog.Header
.MoveToY(0, duration, easing)
.FadeIn(duration, easing);
// since using .finally/.oncomplete after first fadeout made the badge
// not hide sometimes in visual tests(because FinishTransforms()/CancelTransforms()
// didn't apply to transforms that come after the .finally), I'm using a scheduler here
// since using .finally/.oncomplete after first fadeout made the badge not hide
// sometimes in visual tests (https://streamable.com/0qssq), I'm using a scheduler here
Scheduler.AddDelayed(() =>
{
if (!string.IsNullOrEmpty(displayText)) Text.Text = displayText;
@ -79,10 +78,8 @@ namespace osu.Game.Overlays.Changelog.Header
{
Text = new SpriteText
{
TextSize = 21, // web is 16, but here it looks too small?
TextSize = 21, // web: 16,
Text = displayText,
Anchor = Anchor.TopLeft,
Origin = Anchor.TopLeft,
Margin = new MarginPadding
{
Top = 5,
@ -91,7 +88,6 @@ namespace osu.Game.Overlays.Changelog.Header
},
LineBadge = new LineBadge(startCollapsed)
{
Width = 1,
Colour = badgeColour,
RelativeSizeAxes = Axes.X,
}

View File

@ -17,10 +17,7 @@ namespace osu.Game.Overlays.Changelog.Header
Text.Alpha = 0;
}
public void SetText(string displayText)
{
Text.Text = displayText;
}
public void SetText(string displayText) => Text.Text = displayText;
public void Activate(string displayText = null)
{

View File

@ -76,10 +76,8 @@ namespace osu.Game.Overlays.Changelog
{
Anchor = Anchor.TopCentre,
Origin = Anchor.TopCentre,
Width = 1,
Colour = StreamColour.FromStreamName(ChangelogEntry.UpdateStream.Name),
RelativeSizeAxes = Axes.X,
TransitionDuration = 600,
},
};
}

View File

@ -79,6 +79,7 @@ namespace osu.Game.Overlays
},
},
};
OnLoadComplete += d => FetchChangelog(); // is i
Streams.OnSelection = () =>
{
if (Streams.SelectedRelease != null)
@ -86,13 +87,9 @@ namespace osu.Game.Overlays
header.ChangelogEntry = Streams.SelectedRelease;
}
header.ShowReleaseStream();
content.Clear();
content.Clear(); // this should probably happen with some transition
content.Add(new ChangelogContentGroup(Streams.SelectedRelease));
};
Streams.BadgesContainer.OnLoadComplete += d =>
{
FetchChangelog();
};
header.OnListingActivated += () =>
{
Streams.SelectedRelease = null;
@ -151,6 +148,7 @@ namespace osu.Game.Overlays
var req = new GetChangelogLatestBuildsRequest();
req.Success += res =>
{
Streams.BadgesContainer.Clear();
foreach (APIChangelog item in res)
{
Streams.BadgesContainer.Add(new StreamBadge(item));

View File

@ -1,22 +0,0 @@
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using osu.Framework.Allocation;
using osu.Game.Graphics;
namespace osu.Game.Overlays.Toolbar
{
public class ToolbarChangelogButton : ToolbarOverlayToggleButton
{
public ToolbarChangelogButton()
{
SetIcon(FontAwesome.fa_list);
}
[BackgroundDependencyLoader(true)]
private void load(ChangelogOverlay changelog)
{
StateContainer = changelog;
}
}
}