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

Merge branch 'master' into multiplayer-remove-expired-item-removal

This commit is contained in:
Salman Alshamrani 2024-11-23 22:19:21 -05:00 committed by GitHub
commit 956da0383f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 62 additions and 20 deletions

View File

@ -7,7 +7,7 @@ using osu.Game.Online.API;
namespace osu.Game.Online.Rooms namespace osu.Game.Online.Rooms
{ {
public class JoinRoomRequest : APIRequest public class JoinRoomRequest : APIRequest<Room>
{ {
public readonly Room Room; public readonly Room Room;
public readonly string? Password; public readonly string? Password;

View File

@ -268,7 +268,8 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
private void updateScreenModeWarning() private void updateScreenModeWarning()
{ {
if (RuntimeInfo.OS == RuntimeInfo.Platform.macOS) // Can be removed once we stop supporting SDL2.
if (RuntimeInfo.OS == RuntimeInfo.Platform.macOS && !FrameworkEnvironment.UseSDL3)
{ {
if (windowModeDropdown.Current.Value == WindowMode.Fullscreen) if (windowModeDropdown.Current.Value == WindowMode.Fullscreen)
windowModeDropdown.SetNoticeText(LayoutSettingsStrings.FullscreenMacOSNote, true); windowModeDropdown.SetNoticeText(LayoutSettingsStrings.FullscreenMacOSNote, true);

View File

@ -8,6 +8,9 @@ using osu.Game.Graphics.Sprites;
using osuTK; using osuTK;
using osu.Game.Graphics; using osu.Game.Graphics;
using osu.Framework.Bindables; using osu.Framework.Bindables;
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Graphics.Effects;
using osu.Framework.Graphics.Shapes;
using osu.Framework.Localisation; using osu.Framework.Localisation;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
@ -27,26 +30,60 @@ namespace osu.Game.Screens.Menu
public SongTicker() public SongTicker()
{ {
AutoSizeAxes = Axes.Both; AutoSizeAxes = Axes.Both;
Child = new FillFlowContainer InternalChildren = new Drawable[]
{ {
AutoSizeAxes = Axes.Both, new Container
Direction = FillDirection.Vertical,
Spacing = new Vector2(0, 3),
Children = new Drawable[]
{ {
title = new OsuSpriteText Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
Position = new Vector2(5, -5),
Padding = new MarginPadding(-5),
RelativeSizeAxes = Axes.Both,
Children = new Drawable[]
{ {
Anchor = Anchor.TopRight, new CircularContainer
Origin = Anchor.TopRight, {
Font = OsuFont.GetFont(size: 24, weight: FontWeight.Light, italics: true) RelativeSizeAxes = Axes.Both,
}, Masking = true,
artist = new OsuSpriteText EdgeEffect = new EdgeEffectParameters
{ {
Anchor = Anchor.TopRight, Radius = 75,
Origin = Anchor.TopRight, Type = EdgeEffectType.Shadow,
Font = OsuFont.GetFont(size: 16) Colour = OsuColour.Gray(0.04f).Opacity(0.3f),
},
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
AlwaysPresent = true,
Alpha = 0,
},
}
},
} }
} },
new FillFlowContainer
{
AutoSizeAxes = Axes.Both,
Direction = FillDirection.Vertical,
Spacing = new Vector2(0, 3),
Children = new Drawable[]
{
title = new OsuSpriteText
{
Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
Font = OsuFont.GetFont(size: 24, weight: FontWeight.Light, italics: true)
},
artist = new OsuSpriteText
{
Anchor = Anchor.TopRight,
Origin = Anchor.TopRight,
Font = OsuFont.GetFont(size: 16)
}
}
},
}; };
} }

View File

@ -72,9 +72,13 @@ namespace osu.Game.Screens.OnlinePlay.Components
currentJoinRoomRequest?.Cancel(); currentJoinRoomRequest?.Cancel();
currentJoinRoomRequest = new JoinRoomRequest(room, password); currentJoinRoomRequest = new JoinRoomRequest(room, password);
currentJoinRoomRequest.Success += () => currentJoinRoomRequest.Success += result =>
{ {
joinedRoom.Value = room; joinedRoom.Value = room;
AddOrUpdateRoom(result);
room.CopyFrom(result); // Also copy back to the source model, since this is likely to have been stored elsewhere.
onSuccess?.Invoke(room); onSuccess?.Invoke(room);
}; };

View File

@ -71,7 +71,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
return true; return true;
} }
joinRoomRequest.TriggerSuccess(); joinRoomRequest.TriggerSuccess(createResponseRoom(room, true));
return true; return true;
} }