1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-06 04:13:11 +08:00
osu-lazer/osu.Game/Overlays/BeatmapSetOverlay.cs

182 lines
5.9 KiB
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2018-04-13 17:19:50 +08:00
using System.Linq;
2018-04-13 17:19:50 +08:00
using osu.Framework.Allocation;
using osu.Framework.Bindables;
2018-04-13 17:19:50 +08:00
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
2018-10-02 11:02:47 +08:00
using osu.Framework.Input.Events;
2018-04-13 17:19:50 +08:00
using osu.Game.Beatmaps;
using osu.Game.Graphics.Containers;
using osu.Game.Online.API.Requests;
using osu.Game.Overlays.BeatmapSet;
using osu.Game.Overlays.BeatmapSet.Scores;
using osu.Game.Overlays.Comments;
using osu.Game.Rulesets;
2018-11-20 15:51:59 +08:00
using osuTK;
2019-07-09 22:56:08 +08:00
2018-04-13 17:19:50 +08:00
namespace osu.Game.Overlays
{
public class BeatmapSetOverlay : FullscreenOverlay<OverlayHeader> // we don't provide a standard header for now.
2018-04-13 17:19:50 +08:00
{
public const float X_PADDING = 40;
2020-02-05 03:17:27 +08:00
public const float Y_PADDING = 25;
2018-04-13 17:19:50 +08:00
public const float RIGHT_WIDTH = 275;
//todo: should be an OverlayHeader? or maybe not?
protected new readonly Header Header;
2018-04-13 17:19:50 +08:00
2020-02-14 21:14:00 +08:00
[Resolved]
private RulesetStore rulesets { get; set; }
2019-07-10 23:42:14 +08:00
private readonly Bindable<BeatmapSetInfo> beatmapSet = new Bindable<BeatmapSetInfo>();
2018-04-13 17:19:50 +08:00
// receive input outside our bounds so we can trigger a close event on ourselves.
public override bool ReceivePositionalInputAt(Vector2 screenSpacePos) => true;
2018-04-13 17:19:50 +08:00
2020-02-04 19:46:22 +08:00
private readonly Box background;
2018-04-13 17:19:50 +08:00
public BeatmapSetOverlay()
: base(OverlayColourScheme.Blue, null)
2018-04-13 17:19:50 +08:00
{
OverlayScrollContainer scroll;
2019-02-28 18:58:21 +08:00
Info info;
CommentsSection comments;
2018-04-13 17:19:50 +08:00
Children = new Drawable[]
{
2020-02-04 19:46:22 +08:00
background = new Box
2018-04-13 17:19:50 +08:00
{
2020-02-04 19:46:22 +08:00
RelativeSizeAxes = Axes.Both
2018-04-13 17:19:50 +08:00
},
scroll = new OverlayScrollContainer
2018-04-13 17:19:50 +08:00
{
RelativeSizeAxes = Axes.Both,
ScrollbarVisible = false,
Child = new ReverseChildIDFillFlowContainer<BeatmapSetLayoutSection>
2018-04-13 17:19:50 +08:00
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
2020-02-04 19:46:22 +08:00
Spacing = new Vector2(0, 20),
Children = new[]
2018-04-13 17:19:50 +08:00
{
new BeatmapSetLayoutSection
2020-02-04 19:46:22 +08:00
{
Child = new ReverseChildIDFillFlowContainer<Drawable>
2020-02-04 19:46:22 +08:00
{
AutoSizeAxes = Axes.Y,
RelativeSizeAxes = Axes.X,
Direction = FillDirection.Vertical,
Children = new Drawable[]
{
Header = new Header(),
info = new Info()
}
},
},
new ScoresContainer
{
Beatmap = { BindTarget = Header.Picker.Beatmap }
2020-02-04 19:46:22 +08:00
},
comments = new CommentsSection()
2018-04-13 17:19:50 +08:00
},
},
},
};
Header.BeatmapSet.BindTo(beatmapSet);
info.BeatmapSet.BindTo(beatmapSet);
comments.BeatmapSet.BindTo(beatmapSet);
Header.Picker.Beatmap.ValueChanged += b =>
2018-04-13 17:19:50 +08:00
{
info.Beatmap = b.NewValue;
scroll.ScrollToStart();
2018-04-13 17:19:50 +08:00
};
}
[BackgroundDependencyLoader]
2020-02-14 21:14:00 +08:00
private void load()
2018-04-13 17:19:50 +08:00
{
2020-02-04 19:46:22 +08:00
background.Colour = ColourProvider.Background6;
2018-04-13 17:19:50 +08:00
}
2019-05-14 14:19:23 +08:00
protected override void PopOutComplete()
2018-04-13 17:19:50 +08:00
{
2019-05-14 14:19:23 +08:00
base.PopOutComplete();
beatmapSet.Value = null;
2018-04-13 17:19:50 +08:00
}
2018-10-02 11:02:47 +08:00
protected override bool OnClick(ClickEvent e)
2018-04-13 17:19:50 +08:00
{
Hide();
2018-04-13 17:19:50 +08:00
return true;
}
public void FetchAndShowBeatmap(int beatmapId)
{
beatmapSet.Value = null;
var req = new GetBeatmapSetRequest(beatmapId, BeatmapSetLookupType.BeatmapId);
req.Success += res =>
{
beatmapSet.Value = res.ToBeatmapSet(rulesets);
Header.Picker.Beatmap.Value = Header.BeatmapSet.Value.Beatmaps.First(b => b.OnlineBeatmapID == beatmapId);
};
2019-05-14 14:07:18 +08:00
API.Queue(req);
Show();
}
public void FetchAndShowBeatmapSet(int beatmapSetId)
2018-04-13 17:19:50 +08:00
{
beatmapSet.Value = null;
2018-04-13 17:19:50 +08:00
var req = new GetBeatmapSetRequest(beatmapSetId);
req.Success += res => beatmapSet.Value = res.ToBeatmapSet(rulesets);
2019-05-14 14:07:18 +08:00
API.Queue(req);
Show();
2018-04-13 17:19:50 +08:00
}
/// <summary>
/// Show an already fully-populated beatmap set.
/// </summary>
/// <param name="set">The set to show.</param>
public void ShowBeatmapSet(BeatmapSetInfo set)
2018-04-13 17:19:50 +08:00
{
beatmapSet.Value = set;
Show();
2018-04-13 17:19:50 +08:00
}
private class CommentsSection : BeatmapSetLayoutSection
{
public readonly Bindable<BeatmapSetInfo> BeatmapSet = new Bindable<BeatmapSetInfo>();
public CommentsSection()
{
CommentsContainer comments;
Add(comments = new CommentsContainer());
BeatmapSet.BindValueChanged(beatmapSet =>
{
if (beatmapSet.NewValue?.OnlineBeatmapSetID is int onlineBeatmapSetID)
{
Show();
comments.ShowComments(CommentableType.Beatmapset, onlineBeatmapSetID);
}
else
{
Hide();
}
}, true);
}
}
2018-04-13 17:19:50 +08:00
}
}