From 97bd90c0ffa9f090bc8ba323aaf3dbb993ac614f Mon Sep 17 00:00:00 2001 From: Joseph Madamba Date: Wed, 6 Sep 2023 14:08:16 -0700 Subject: [PATCH 1/2] Link new song select wedge title and artist to search text box --- osu.Game/Screens/Select/BeatmapDetails.cs | 12 ++--- osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs | 50 +++++++++++++------ osu.Game/Screens/Select/SongSelect.cs | 9 ++++ 3 files changed, 47 insertions(+), 24 deletions(-) diff --git a/osu.Game/Screens/Select/BeatmapDetails.cs b/osu.Game/Screens/Select/BeatmapDetails.cs index 712b610515..179323176a 100644 --- a/osu.Game/Screens/Select/BeatmapDetails.cs +++ b/osu.Game/Screens/Select/BeatmapDetails.cs @@ -141,9 +141,9 @@ namespace osu.Game.Screens.Select LayoutEasing = Easing.OutQuad, Children = new[] { - description = new MetadataSectionDescription(searchOnSongSelect), - source = new MetadataSectionSource(searchOnSongSelect), - tags = new MetadataSectionTags(searchOnSongSelect), + description = new MetadataSectionDescription(query => songSelect?.Search(query)), + source = new MetadataSectionSource(query => songSelect?.Search(query)), + tags = new MetadataSectionTags(query => songSelect?.Search(query)), }, }, }, @@ -176,12 +176,6 @@ namespace osu.Game.Screens.Select }, loading = new LoadingLayer(true) }; - - void searchOnSongSelect(string text) - { - if (songSelect != null) - songSelect.FilterControl.CurrentTextSearch.Value = text; - } } private void updateStatistics() diff --git a/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs b/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs index a7bfbc8214..1c1a20b596 100644 --- a/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs +++ b/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs @@ -15,6 +15,7 @@ using osu.Game.Graphics; using osu.Game.Graphics.Sprites; using osu.Framework.Graphics.Shapes; using osu.Framework.Localisation; +using osu.Game.Graphics.Containers; using osu.Game.Graphics.UserInterface; using osu.Game.Rulesets; @@ -270,38 +271,57 @@ namespace osu.Game.Screens.Select } [BackgroundDependencyLoader] - private void load() + private void load(SongSelect? songSelect, LocalisationManager localisation) { var metadata = working.Metadata; + var titleText = new RomanisableString(metadata.TitleUnicode, metadata.Title); + var artistText = new RomanisableString(metadata.ArtistUnicode, metadata.Artist); + Child = new FillFlowContainer { Name = "Top-left aligned metadata", Direction = FillDirection.Vertical, - Padding = new MarginPadding { Left = text_margin, Right = text_margin + shear_width, Top = 12 }, + Padding = new MarginPadding { Left = text_margin, Top = 12 }, AutoSizeAxes = Axes.Y, RelativeSizeAxes = Axes.X, Children = new Drawable[] { - TitleLabel = new TruncatingSpriteText + new OsuHoverContainer { - Shadow = true, - Text = new RomanisableString(metadata.TitleUnicode, metadata.Title), - Font = OsuFont.TorusAlternate.With(size: 40, weight: FontWeight.SemiBold), - RelativeSizeAxes = Axes.X, + AutoSizeAxes = Axes.Both, + Action = () => songSelect?.Search(titleText.GetPreferred(localisation.CurrentParameters.Value.PreferOriginalScript)), + Child = TitleLabel = new TruncatingSpriteText + { + Shadow = true, + Text = titleText, + Font = OsuFont.TorusAlternate.With(size: 40, weight: FontWeight.SemiBold), + }, }, - ArtistLabel = new TruncatingSpriteText + new OsuHoverContainer { - // TODO : figma design has a diffused shadow, instead of the solid one present here, not possible currently as far as i'm aware. - Shadow = true, - Text = new RomanisableString(metadata.ArtistUnicode, metadata.Artist), - // Not sure if this should be semi bold or medium - Font = OsuFont.Torus.With(size: 20, weight: FontWeight.SemiBold), - RelativeSizeAxes = Axes.X, - } + AutoSizeAxes = Axes.Both, + Action = () => songSelect?.Search(artistText.GetPreferred(localisation.CurrentParameters.Value.PreferOriginalScript)), + Child = ArtistLabel = new TruncatingSpriteText + { + // TODO : figma design has a diffused shadow, instead of the solid one present here, not possible currently as far as i'm aware. + Shadow = true, + Text = artistText, + // Not sure if this should be semi bold or medium + Font = OsuFont.Torus.With(size: 20, weight: FontWeight.SemiBold), + }, + }, } }; } + + protected override void UpdateAfterChildren() + { + base.UpdateAfterChildren(); + + TitleLabel.MaxWidth = DrawWidth - text_margin * 2 - shear_width; + ArtistLabel.MaxWidth = DrawWidth - text_margin - shear_width; + } } } } diff --git a/osu.Game/Screens/Select/SongSelect.cs b/osu.Game/Screens/Select/SongSelect.cs index cca18b93af..809ffb307c 100644 --- a/osu.Game/Screens/Select/SongSelect.cs +++ b/osu.Game/Screens/Select/SongSelect.cs @@ -390,6 +390,15 @@ namespace osu.Game.Screens.Select this.Push(new EditorLoader()); } + /// + /// Set the query to the search text box. + /// + /// The string to search. + public void Search(string query) + { + FilterControl.CurrentTextSearch.Value = query; + } + /// /// Call to make a selection and perform the default action for this SongSelect. /// From d0780fb765d231f565d58058a8771e5c5dd3d3a4 Mon Sep 17 00:00:00 2001 From: Joseph Madamba Date: Wed, 6 Sep 2023 15:01:55 -0700 Subject: [PATCH 2/2] Add comment explaining the max width --- osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs b/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs index 1c1a20b596..3c76ae1f08 100644 --- a/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs +++ b/osu.Game/Screens/Select/BeatmapInfoWedgeV2.cs @@ -319,6 +319,8 @@ namespace osu.Game.Screens.Select { base.UpdateAfterChildren(); + // best effort to confine the auto-sized text to wedge bounds + // the artist label doesn't have an extra text_margin as it doesn't touch the right metadata TitleLabel.MaxWidth = DrawWidth - text_margin * 2 - shear_width; ArtistLabel.MaxWidth = DrawWidth - text_margin - shear_width; }