osu/osu.Game/Overlays/BeatmapListing/Panels/GridBeatmapPanel.cs

269 lines
12 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 09:19:50 +00:00
using osu.Framework.Allocation;
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Input.Events;
using osu.Framework.Localisation;
2018-04-13 09:19:50 +00:00
using osu.Game.Beatmaps;
using osu.Game.Beatmaps.Drawables;
using osu.Game.Graphics;
2019-05-14 09:11:32 +00:00
using osu.Game.Graphics.Containers;
using osu.Game.Graphics.Sprites;
2021-01-13 08:29:30 +00:00
using osu.Game.Overlays.BeatmapSet;
using osuTK;
using osuTK.Graphics;
2018-04-13 09:19:50 +00:00
namespace osu.Game.Overlays.BeatmapListing.Panels
2018-04-13 09:19:50 +00:00
{
2020-04-21 11:55:33 +00:00
public class GridBeatmapPanel : BeatmapPanel
2018-04-13 09:19:50 +00:00
{
private const float horizontal_padding = 10;
private const float vertical_padding = 5;
private FillFlowContainer bottomPanel, statusContainer, titleContainer, artistContainer;
2018-04-13 09:19:50 +00:00
private PlayButton playButton;
private Box progressBar;
protected override PlayButton PlayButton => playButton;
protected override Box PreviewBar => progressBar;
2020-04-21 11:55:33 +00:00
public GridBeatmapPanel(BeatmapSetInfo beatmap)
2019-02-28 04:31:40 +00:00
: base(beatmap)
2018-04-13 09:19:50 +00:00
{
Width = 380;
2020-05-05 01:31:11 +00:00
Height = 140 + vertical_padding; // full height of all the elements plus vertical padding (autosize uses the image)
2018-04-13 09:19:50 +00:00
}
protected override void LoadComplete()
{
base.LoadComplete();
bottomPanel.LayoutDuration = 200;
bottomPanel.LayoutEasing = Easing.Out;
bottomPanel.Origin = Anchor.BottomLeft;
}
[BackgroundDependencyLoader]
private void load(OsuColour colours)
2018-04-13 09:19:50 +00:00
{
Content.CornerRadius = 4;
AddRange(new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
Colour = Color4.Black.Opacity(0.5f),
},
bottomPanel = new FillFlowContainer
{
Anchor = Anchor.BottomLeft,
Origin = Anchor.TopLeft,
Direction = FillDirection.Vertical,
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Spacing = new Vector2(0f, vertical_padding),
Children = new Drawable[]
{
new FillFlowContainer
{
AutoSizeAxes = Axes.Both,
Padding = new MarginPadding { Left = horizontal_padding, Right = horizontal_padding },
Direction = FillDirection.Vertical,
2021-01-13 08:29:30 +00:00
Children = new Drawable[]
2018-04-13 09:19:50 +00:00
{
2021-01-13 08:29:30 +00:00
titleContainer = new FillFlowContainer
2018-04-13 09:19:50 +00:00
{
2021-01-13 08:29:30 +00:00
AutoSizeAxes = Axes.Both,
Direction = FillDirection.Horizontal,
Children = new Drawable[]
{
new OsuSpriteText
{
Text = new RomanisableString(SetInfo.Metadata.TitleUnicode, SetInfo.Metadata.Title),
2021-01-13 08:29:30 +00:00
Font = OsuFont.GetFont(size: 18, weight: FontWeight.Bold, italics: true)
},
}
2018-04-13 09:19:50 +00:00
},
artistContainer = new FillFlowContainer
2018-04-13 09:19:50 +00:00
{
AutoSizeAxes = Axes.Both,
Direction = FillDirection.Horizontal,
Children = new Drawable[]
{
new OsuSpriteText
{
Text = new RomanisableString(SetInfo.Metadata.ArtistUnicode, SetInfo.Metadata.Artist),
Font = OsuFont.GetFont(weight: FontWeight.Bold, italics: true)
}
}
}
2018-04-13 09:19:50 +00:00
},
},
new Container
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
},
progressBar = new Box
{
Origin = Anchor.BottomLeft,
RelativeSizeAxes = Axes.X,
BypassAutoSizeAxes = Axes.Both,
Size = new Vector2(0, 3),
Alpha = 0,
Colour = colours.Yellow,
},
new FillFlowContainer
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Padding = new MarginPadding
{
Top = vertical_padding,
Bottom = vertical_padding,
Left = horizontal_padding,
Right = horizontal_padding,
},
Children = new Drawable[]
{
2019-05-14 09:11:32 +00:00
new LinkFlowContainer(s =>
2018-04-13 09:19:50 +00:00
{
2019-05-14 09:11:32 +00:00
s.Shadow = false;
s.Font = OsuFont.GetFont(size: 14);
}).With(d =>
{
d.AutoSizeAxes = Axes.Both;
d.AddText("mapped by ", t => t.Colour = colours.Gray5);
d.AddUserLink(SetInfo.Metadata.Author);
}),
2018-04-13 09:19:50 +00:00
new Container
{
AutoSizeAxes = Axes.X,
Height = 14,
Children = new[]
{
new OsuSpriteText
{
Text = SetInfo.Metadata.Source,
Font = OsuFont.GetFont(size: 14),
2018-04-13 09:19:50 +00:00
Shadow = false,
Colour = colours.Gray5,
Alpha = string.IsNullOrEmpty(SetInfo.Metadata.Source) ? 0f : 1f,
},
},
},
new FillFlowContainer
{
AutoSizeAxes = Axes.X,
Height = 20,
Margin = new MarginPadding { Top = vertical_padding, Bottom = vertical_padding },
Spacing = new Vector2(3),
2019-08-25 02:44:56 +00:00
Children = GetDifficultyIcons(colours),
2018-04-13 09:19:50 +00:00
},
},
},
new BeatmapPanelDownloadButton(SetInfo)
2018-04-13 09:19:50 +00:00
{
Size = new Vector2(50, 30),
2018-04-13 09:19:50 +00:00
Margin = new MarginPadding(horizontal_padding),
Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
2018-04-13 09:19:50 +00:00
},
},
},
},
},
new FillFlowContainer
{
Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
AutoSizeAxes = Axes.Both,
Direction = FillDirection.Vertical,
Margin = new MarginPadding { Top = vertical_padding, Right = vertical_padding },
Children = new[]
{
2019-04-02 10:55:24 +00:00
new Statistic(FontAwesome.Solid.PlayCircle, SetInfo.OnlineInfo?.PlayCount ?? 0),
new Statistic(FontAwesome.Solid.Heart, SetInfo.OnlineInfo?.FavouriteCount ?? 0),
2018-04-13 09:19:50 +00:00
},
},
statusContainer = new FillFlowContainer
{
AutoSizeAxes = Axes.Both,
Margin = new MarginPadding { Top = 5, Left = 5 },
Spacing = new Vector2(5),
},
2018-05-31 15:09:19 +00:00
playButton = new PlayButton(SetInfo)
{
Margin = new MarginPadding { Top = 5, Left = 10 },
Size = new Vector2(30),
Alpha = 0,
},
2018-04-13 09:19:50 +00:00
});
2021-01-13 08:29:30 +00:00
if (SetInfo.OnlineInfo?.HasExplicitContent ?? false)
{
2021-01-17 13:40:24 +00:00
titleContainer.Add(new ExplicitContentBeatmapPill
2021-01-13 08:29:30 +00:00
{
Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft,
Margin = new MarginPadding { Left = 10f, Top = 2f },
});
}
if (SetInfo.OnlineInfo?.TrackId != null)
{
artistContainer.Add(new FeaturedArtistBeatmapPill
{
Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft,
Margin = new MarginPadding { Left = 10f, Top = 2f },
});
}
2018-04-13 09:19:50 +00:00
if (SetInfo.OnlineInfo?.HasVideo ?? false)
{
2019-04-02 10:55:24 +00:00
statusContainer.Add(new IconPill(FontAwesome.Solid.Film));
2018-04-13 09:19:50 +00:00
}
2018-05-31 15:09:19 +00:00
if (SetInfo.OnlineInfo?.HasStoryboard ?? false)
{
2019-04-02 10:55:24 +00:00
statusContainer.Add(new IconPill(FontAwesome.Solid.Image));
2018-05-31 15:09:19 +00:00
}
statusContainer.Add(new BeatmapSetOnlineStatusPill
2018-04-13 09:19:50 +00:00
{
TextSize = 12,
TextPadding = new MarginPadding { Horizontal = 10, Vertical = 5 },
2018-04-13 09:19:50 +00:00
Status = SetInfo.OnlineInfo?.Status ?? BeatmapSetOnlineStatus.None,
});
2018-06-01 13:19:11 +00:00
PreviewPlaying.ValueChanged += _ => updateStatusContainer();
2018-04-13 09:19:50 +00:00
}
2018-10-02 03:02:47 +00:00
protected override bool OnHover(HoverEvent e)
2018-04-13 09:19:50 +00:00
{
2018-06-01 13:19:11 +00:00
updateStatusContainer();
2018-10-02 03:02:47 +00:00
return base.OnHover(e);
2018-04-13 09:19:50 +00:00
}
2018-10-02 03:02:47 +00:00
protected override void OnHoverLost(HoverLostEvent e)
2018-04-13 09:19:50 +00:00
{
2018-10-02 03:02:47 +00:00
base.OnHoverLost(e);
2018-06-01 13:19:11 +00:00
updateStatusContainer();
2018-04-13 09:19:50 +00:00
}
2018-05-31 15:09:19 +00:00
2019-02-21 09:56:34 +00:00
private void updateStatusContainer() => statusContainer.FadeTo(IsHovered || PreviewPlaying.Value ? 0 : 1, 120, Easing.InOutQuint);
2018-04-13 09:19:50 +00:00
}
}