mirror of
https://github.com/ppy/osu
synced 2025-03-22 02:47:04 +00:00
Remove "multiplayer" references from subclass and move to appropriate place
This commit is contained in:
parent
ed028e8d26
commit
ae9c58be30
osu.Game/Screens/OnlinePlay/Match
@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
@ -6,26 +6,28 @@ using System.Linq;
|
|||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Online.Rooms;
|
using osu.Game.Online.Rooms;
|
||||||
|
using osu.Game.Overlays;
|
||||||
|
using osu.Game.Overlays.Mods;
|
||||||
|
using osu.Game.Rulesets;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Mods
|
namespace osu.Game.Screens.OnlinePlay.Match
|
||||||
{
|
{
|
||||||
public partial class MultiplayerModSelectOverlay : UserModSelectOverlay
|
public partial class RoomModSelectOverlay : UserModSelectOverlay
|
||||||
{
|
{
|
||||||
public MultiplayerModSelectOverlay(OverlayColourScheme colourScheme = OverlayColourScheme.Plum)
|
public RoomModSelectOverlay(OverlayColourScheme colourScheme = OverlayColourScheme.Plum)
|
||||||
: base(colourScheme)
|
: base(colourScheme)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
[Resolved(CanBeNull = true)]
|
[Resolved(CanBeNull = true)]
|
||||||
private IBindable<PlaylistItem>? multiplayerRoomItem { get; set; }
|
private IBindable<PlaylistItem>? selectedItem { get; set; }
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private OsuGameBase game { get; set; } = null!;
|
private OsuGameBase game { get; set; } = null!;
|
||||||
|
|
||||||
protected override BeatmapAttributesDisplay GetBeatmapAttributesDisplay => new MultiplayerBeatmapAttributesDisplay
|
protected override BeatmapAttributesDisplay GetBeatmapAttributesDisplay => new RoomBeatmapAttributesDisplay
|
||||||
{
|
{
|
||||||
Anchor = Anchor.BottomRight,
|
Anchor = Anchor.BottomRight,
|
||||||
Origin = Anchor.BottomRight,
|
Origin = Anchor.BottomRight,
|
||||||
@ -35,7 +37,7 @@ namespace osu.Game.Overlays.Mods
|
|||||||
protected override void LoadComplete()
|
protected override void LoadComplete()
|
||||||
{
|
{
|
||||||
base.LoadComplete();
|
base.LoadComplete();
|
||||||
multiplayerRoomItem?.BindValueChanged(_ => SelectedMods.TriggerChange());
|
selectedItem?.BindValueChanged(_ => SelectedMods.TriggerChange());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override IEnumerable<Mod> AllSelectedMods
|
protected override IEnumerable<Mod> AllSelectedMods
|
||||||
@ -44,10 +46,10 @@ namespace osu.Game.Overlays.Mods
|
|||||||
{
|
{
|
||||||
IEnumerable<Mod> allMods = SelectedMods.Value;
|
IEnumerable<Mod> allMods = SelectedMods.Value;
|
||||||
|
|
||||||
if (multiplayerRoomItem?.Value != null)
|
if (selectedItem?.Value != null)
|
||||||
{
|
{
|
||||||
Ruleset ruleset = game.Ruleset.Value.CreateInstance();
|
Ruleset ruleset = game.Ruleset.Value.CreateInstance();
|
||||||
var multiplayerRoomMods = multiplayerRoomItem.Value.RequiredMods.Select(m => m.ToMod(ruleset));
|
var multiplayerRoomMods = selectedItem.Value.RequiredMods.Select(m => m.ToMod(ruleset));
|
||||||
allMods = allMods.Concat(multiplayerRoomMods);
|
allMods = allMods.Concat(multiplayerRoomMods);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +58,7 @@ namespace osu.Game.Overlays.Mods
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public partial class MultiplayerBeatmapAttributesDisplay : BeatmapAttributesDisplay
|
public partial class RoomBeatmapAttributesDisplay : BeatmapAttributesDisplay
|
||||||
{
|
{
|
||||||
[Resolved(CanBeNull = true)]
|
[Resolved(CanBeNull = true)]
|
||||||
private IBindable<PlaylistItem>? multiplayerRoomItem { get; set; }
|
private IBindable<PlaylistItem>? multiplayerRoomItem { get; set; }
|
@ -241,7 +241,7 @@ namespace osu.Game.Screens.OnlinePlay.Match
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
LoadComponent(UserModsSelectOverlay = new MultiplayerModSelectOverlay
|
LoadComponent(UserModsSelectOverlay = new RoomModSelectOverlay
|
||||||
{
|
{
|
||||||
SelectedMods = { BindTarget = UserMods },
|
SelectedMods = { BindTarget = UserMods },
|
||||||
IsValidMod = _ => false
|
IsValidMod = _ => false
|
||||||
|
Loading…
Reference in New Issue
Block a user