1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-11 16:27:26 +08:00
osu-lazer/osu.Game/Overlays/ChangelogOverlay.cs

195 lines
6.5 KiB
C#
Raw Normal View History

2018-07-17 05:50:22 +08:00
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using OpenTK;
using OpenTK.Graphics;
2018-07-20 01:07:24 +08:00
using osu.Framework.Allocation;
using osu.Framework.Audio;
using osu.Framework.Audio.Sample;
2018-07-17 05:50:22 +08:00
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
using osu.Game.Graphics;
using osu.Game.Graphics.Containers;
2018-07-19 01:32:15 +08:00
using osu.Game.Input.Bindings;
2018-07-20 01:07:24 +08:00
using osu.Game.Online.API;
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2018-07-17 05:50:22 +08:00
using osu.Game.Overlays.Changelog;
2018-07-23 02:27:50 +08:00
using System;
2018-07-17 05:50:22 +08:00
namespace osu.Game.Overlays
{
public class ChangelogOverlay : WaveOverlayContainer
{
2018-07-19 01:32:15 +08:00
private readonly ChangelogHeader header;
2018-07-23 00:35:29 +08:00
private readonly ChangelogBadges badges;
private readonly ChangelogChart chart;
2018-07-23 00:35:29 +08:00
private readonly ChangelogContent content;
private readonly ScrollContainer scroll;
2018-07-23 00:35:29 +08:00
private readonly Color4 purple = new Color4(191, 4, 255, 255);
2018-07-20 01:07:24 +08:00
2018-07-25 00:41:47 +08:00
private SampleChannel sampleBack;
2018-07-20 01:07:24 +08:00
private APIAccess api;
2018-07-17 05:50:22 +08:00
2018-07-23 00:35:29 +08:00
private bool isAtListing;
private float savedScrollPosition;
2018-07-18 00:32:11 +08:00
2018-07-25 00:41:47 +08:00
// receive input outside our bounds so we can trigger a close event on ourselves.
public override bool ReceiveMouseInputAt(Vector2 screenSpacePos) => true;
2018-07-17 05:50:22 +08:00
public ChangelogOverlay()
{
2018-07-18 00:32:11 +08:00
// these possibly need adjusting?
Waves.FirstWaveColour = OsuColour.FromHex(@"bf04ff");
Waves.SecondWaveColour = OsuColour.FromHex(@"8F03BF");
Waves.ThirdWaveColour = OsuColour.FromHex(@"600280");
Waves.FourthWaveColour = OsuColour.FromHex(@"300140");
2018-07-17 05:50:22 +08:00
Anchor = Anchor.TopCentre;
Origin = Anchor.TopCentre;
RelativeSizeAxes = Axes.Both;
Width = 0.85f;
Masking = true;
2018-07-18 00:32:11 +08:00
2018-07-17 05:50:22 +08:00
EdgeEffect = new EdgeEffectParameters
{
Colour = Color4.Black.Opacity(0),
Type = EdgeEffectType.Shadow,
Radius = 3,
Offset = new Vector2(0f, 1f),
};
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
2018-07-22 05:00:05 +08:00
Colour = new Color4(49, 36, 54, 255),
2018-07-17 05:50:22 +08:00
},
scroll = new ScrollContainer
2018-07-17 05:50:22 +08:00
{
RelativeSizeAxes = Axes.Both,
ScrollbarVisible = false,
Child = new ReverseChildIDFillFlowContainer<Drawable>
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Children = new Drawable[]
{
header = new ChangelogHeader(),
2018-07-23 00:35:29 +08:00
badges = new ChangelogBadges(),
chart = new ChangelogChart(),
2018-07-22 19:04:39 +08:00
content = new ChangelogContent()
2018-07-17 05:50:22 +08:00
},
},
},
};
header.ListingSelected += FetchAndShowListing;
2018-07-23 02:27:50 +08:00
badges.Selected += onBuildSelected;
content.BuildSelected += onBuildSelected;
2018-07-17 05:50:22 +08:00
}
2018-07-25 00:41:47 +08:00
[BackgroundDependencyLoader]
private void load(APIAccess api, AudioManager audio)
2018-07-19 01:32:15 +08:00
{
2018-07-25 00:41:47 +08:00
this.api = api;
sampleBack = audio.Sample.Get(@"UI/generic-select-soft"); // @"UI/screen-back" feels non-fitting here
}
2018-07-19 01:32:15 +08:00
2018-07-25 00:41:47 +08:00
protected override void LoadComplete()
{
var req = new GetChangelogLatestBuildsRequest();
req.Success += badges.Populate;
api.Queue(req);
FetchAndShowListing();
base.LoadComplete();
2018-07-19 01:32:15 +08:00
}
2018-07-17 05:50:22 +08:00
protected override void PopIn()
{
base.PopIn();
FadeEdgeEffectTo(0.25f, WaveContainer.APPEAR_DURATION, Easing.In);
}
protected override void PopOut()
{
base.PopOut();
FadeEdgeEffectTo(0, WaveContainer.DISAPPEAR_DURATION, Easing.Out);
}
2018-07-20 01:07:24 +08:00
2018-07-25 00:41:47 +08:00
public override bool OnPressed(GlobalAction action)
2018-07-23 02:27:50 +08:00
{
2018-07-25 00:41:47 +08:00
switch (action)
{
case GlobalAction.Back:
if (isAtListing)
State = Visibility.Hidden;
else
{
FetchAndShowListing();
sampleBack?.Play();
}
return true;
}
2018-07-23 02:27:50 +08:00
2018-07-25 00:41:47 +08:00
return false;
2018-07-20 01:07:24 +08:00
}
2018-07-25 00:41:47 +08:00
private void onBuildSelected(APIChangelog build, EventArgs e) => FetchAndShowBuild(build);
2018-07-23 04:13:14 +08:00
2018-07-23 00:35:29 +08:00
/// <summary>
/// If we're not already at it, fetches and shows changelog listing.
2018-07-23 00:35:29 +08:00
/// </summary>
public void FetchAndShowListing()
2018-07-20 01:07:24 +08:00
{
header.ShowListing();
if (isAtListing)
return;
2018-07-23 04:13:14 +08:00
isAtListing = true;
var req = new GetChangelogRequest();
2018-07-23 00:35:29 +08:00
badges.SelectNone();
chart.ShowAllUpdateStreams();
req.Success += listing =>
{
content.ShowListing(listing);
scroll.ScrollTo(savedScrollPosition);
};
2018-07-23 00:35:29 +08:00
api.Queue(req);
}
/// <summary>
/// Fetches and shows a specific build from a specific update stream.
/// </summary>
public void FetchAndShowBuild(APIChangelog build, bool sentByBadges = false)
2018-07-23 00:35:29 +08:00
{
var req = new GetChangelogBuildRequest(build.UpdateStream.Name, build.Version);
if (build.UpdateStream.DisplayName != null && build.DisplayVersion != null)
header.ShowBuild(build.UpdateStream.DisplayName, build.DisplayVersion);
else
req.Success += res => header.ShowBuild(res.UpdateStream.DisplayName, res.DisplayVersion);
2018-07-23 04:13:14 +08:00
if (!sentByBadges)
badges.SelectUpdateStream(build.UpdateStream.Name);
chart.ShowUpdateStream(build.UpdateStream.Name);
req.Success += APIChangelog =>
{
content.ShowBuild(APIChangelog);
if (scroll.Current > scroll.GetChildPosInContent(content))
scroll.ScrollTo(content);
2018-07-25 03:19:29 +08:00
if (isAtListing)
savedScrollPosition = scroll.Current;
isAtListing = false;
};
2018-07-20 01:07:24 +08:00
api.Queue(req);
}
2018-07-17 05:50:22 +08:00
}
}