mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 07:23:14 +08:00
Make beatmap selection work
This commit is contained in:
parent
5f0bde581c
commit
eadbe4c470
@ -1,43 +0,0 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using NUnit.Framework;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Screens.Multi.Screens.Match;
|
|
||||||
|
|
||||||
namespace osu.Game.Tests.Visual
|
|
||||||
{
|
|
||||||
[TestFixture]
|
|
||||||
public class TestCaseMatchHeader : OsuTestCase
|
|
||||||
{
|
|
||||||
public TestCaseMatchHeader()
|
|
||||||
{
|
|
||||||
Header header = new Header();
|
|
||||||
Add(header);
|
|
||||||
|
|
||||||
AddStep(@"set beatmap set", () => header.BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/760757/covers/cover.jpg?1526944540",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"change beatmap set", () => header.BeatmapSet = new BeatmapSetInfo
|
|
||||||
{
|
|
||||||
OnlineInfo = new BeatmapSetOnlineInfo
|
|
||||||
{
|
|
||||||
Covers = new BeatmapSetOnlineCovers
|
|
||||||
{
|
|
||||||
Cover = @"https://assets.ppy.sh/beatmaps/761883/covers/cover.jpg?1525557400",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
AddStep(@"null beatmap set", () => header.BeatmapSet = null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,50 @@
|
|||||||
|
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||||
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Configuration;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
|
||||||
|
namespace osu.Game.Beatmaps.Drawables
|
||||||
|
{
|
||||||
|
public class UpdateableBeatmapBackgroundSprite : ModelBackedDrawable<WorkingBeatmap>
|
||||||
|
{
|
||||||
|
public readonly IBindable<WorkingBeatmap> Beatmap = new Bindable<WorkingBeatmap>();
|
||||||
|
|
||||||
|
[Resolved]
|
||||||
|
private OsuGameBase game { get; set; }
|
||||||
|
|
||||||
|
public UpdateableBeatmapBackgroundSprite()
|
||||||
|
{
|
||||||
|
Beatmap.BindValueChanged(b => Schedule(() => Model = b));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override Drawable CreateDrawable(WorkingBeatmap model)
|
||||||
|
{
|
||||||
|
Drawable drawable = model == null ? (Drawable)new DefaultSprite() : new BeatmapBackgroundSprite(model);
|
||||||
|
|
||||||
|
drawable.RelativeSizeAxes = Axes.Both;
|
||||||
|
drawable.Anchor = Anchor.Centre;
|
||||||
|
drawable.Origin = Anchor.Centre;
|
||||||
|
drawable.FillMode = FillMode.Fill;
|
||||||
|
|
||||||
|
return drawable;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override double FadeDuration => 400;
|
||||||
|
|
||||||
|
private class DefaultSprite : Sprite
|
||||||
|
{
|
||||||
|
[Resolved]
|
||||||
|
private IBindableBeatmap gameBeatmap { get; set; }
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
Texture = gameBeatmap.Default.Background;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -44,9 +44,14 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
private readonly Bindable<User> hostBind = new Bindable<User>();
|
private readonly Bindable<User> hostBind = new Bindable<User>();
|
||||||
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
||||||
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
||||||
private readonly Bindable<BeatmapInfo> beatmapBind = new Bindable<BeatmapInfo>();
|
private readonly Bindable<BeatmapInfo> roomBeatmap = new Bindable<BeatmapInfo>();
|
||||||
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
||||||
|
|
||||||
|
private readonly Bindable<WorkingBeatmap> beatmap = new Bindable<WorkingBeatmap>();
|
||||||
|
|
||||||
|
[Resolved]
|
||||||
|
private BeatmapManager beatmaps { get; set; }
|
||||||
|
|
||||||
public readonly Room Room;
|
public readonly Room Room;
|
||||||
|
|
||||||
private SelectionState state;
|
private SelectionState state;
|
||||||
@ -101,7 +106,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
private void load(OsuColour colours)
|
private void load(OsuColour colours)
|
||||||
{
|
{
|
||||||
Box sideStrip;
|
Box sideStrip;
|
||||||
UpdateableBeatmapSetCover cover;
|
UpdateableBeatmapBackgroundSprite background;
|
||||||
OsuSpriteText name, status;
|
OsuSpriteText name, status;
|
||||||
ParticipantInfo participantInfo;
|
ParticipantInfo participantInfo;
|
||||||
BeatmapTitle beatmapTitle;
|
BeatmapTitle beatmapTitle;
|
||||||
@ -137,12 +142,13 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
RelativeSizeAxes = Axes.Y,
|
RelativeSizeAxes = Axes.Y,
|
||||||
Width = side_strip_width,
|
Width = side_strip_width,
|
||||||
},
|
},
|
||||||
cover = new UpdateableBeatmapSetCover
|
new Container
|
||||||
{
|
{
|
||||||
Width = cover_width,
|
|
||||||
RelativeSizeAxes = Axes.Y,
|
RelativeSizeAxes = Axes.Y,
|
||||||
|
Width = cover_width,
|
||||||
Masking = true,
|
Masking = true,
|
||||||
Margin = new MarginPadding { Left = side_strip_width },
|
Margin = new MarginPadding { Left = side_strip_width },
|
||||||
|
Child = background = new UpdateableBeatmapBackgroundSprite { RelativeSizeAxes = Axes.Both }
|
||||||
},
|
},
|
||||||
new Container
|
new Container
|
||||||
{
|
{
|
||||||
@ -216,9 +222,11 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
d.FadeColour(s.GetAppropriateColour(colours), transition_duration);
|
d.FadeColour(s.GetAppropriateColour(colours), transition_duration);
|
||||||
};
|
};
|
||||||
|
|
||||||
beatmapBind.ValueChanged += b =>
|
background.Beatmap.BindTo(beatmap);
|
||||||
|
|
||||||
|
roomBeatmap.ValueChanged += b =>
|
||||||
{
|
{
|
||||||
cover.BeatmapSet = b?.BeatmapSet;
|
beatmap.Value = beatmaps.GetWorkingBeatmap(b);
|
||||||
beatmapTitle.Beatmap = b;
|
beatmapTitle.Beatmap = b;
|
||||||
modeTypeInfo.Beatmap = b;
|
modeTypeInfo.Beatmap = b;
|
||||||
};
|
};
|
||||||
@ -227,7 +235,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
hostBind.BindTo(Room.Host);
|
hostBind.BindTo(Room.Host);
|
||||||
statusBind.BindTo(Room.Status);
|
statusBind.BindTo(Room.Status);
|
||||||
typeBind.BindTo(Room.Type);
|
typeBind.BindTo(Room.Type);
|
||||||
beatmapBind.BindTo(Room.Beatmap);
|
roomBeatmap.BindTo(Room.Beatmap);
|
||||||
participantsBind.BindTo(Room.Participants);
|
participantsBind.BindTo(Room.Participants);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,13 +32,15 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
private readonly Bindable<User> hostBind = new Bindable<User>();
|
private readonly Bindable<User> hostBind = new Bindable<User>();
|
||||||
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
||||||
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
||||||
private readonly Bindable<BeatmapInfo> beatmapBind = new Bindable<BeatmapInfo>();
|
private readonly Bindable<BeatmapInfo> roomBeatmap = new Bindable<BeatmapInfo>();
|
||||||
private readonly Bindable<int?> maxParticipantsBind = new Bindable<int?>();
|
private readonly Bindable<int?> maxParticipantsBind = new Bindable<int?>();
|
||||||
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
||||||
|
|
||||||
|
private readonly Bindable<WorkingBeatmap> beatmap = new Bindable<WorkingBeatmap>();
|
||||||
|
|
||||||
private OsuColour colours;
|
private OsuColour colours;
|
||||||
private Box statusStrip;
|
private Box statusStrip;
|
||||||
private UpdateableBeatmapSetCover cover;
|
private UpdateableBeatmapBackgroundSprite background;
|
||||||
private ParticipantCount participantCount;
|
private ParticipantCount participantCount;
|
||||||
private FillFlowContainer topFlow, participantsFlow;
|
private FillFlowContainer topFlow, participantsFlow;
|
||||||
private OsuSpriteText name, status;
|
private OsuSpriteText name, status;
|
||||||
@ -46,6 +48,9 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
private ScrollContainer participantsScroll;
|
private ScrollContainer participantsScroll;
|
||||||
private ParticipantInfo participantInfo;
|
private ParticipantInfo participantInfo;
|
||||||
|
|
||||||
|
[Resolved]
|
||||||
|
private BeatmapManager beatmaps { get; set; }
|
||||||
|
|
||||||
private Room room;
|
private Room room;
|
||||||
public Room Room
|
public Room Room
|
||||||
{
|
{
|
||||||
@ -59,7 +64,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
hostBind.UnbindBindings();
|
hostBind.UnbindBindings();
|
||||||
statusBind.UnbindBindings();
|
statusBind.UnbindBindings();
|
||||||
typeBind.UnbindBindings();
|
typeBind.UnbindBindings();
|
||||||
beatmapBind.UnbindBindings();
|
roomBeatmap.UnbindBindings();
|
||||||
maxParticipantsBind.UnbindBindings();
|
maxParticipantsBind.UnbindBindings();
|
||||||
participantsBind.UnbindBindings();
|
participantsBind.UnbindBindings();
|
||||||
|
|
||||||
@ -69,7 +74,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
hostBind.BindTo(room.Host);
|
hostBind.BindTo(room.Host);
|
||||||
statusBind.BindTo(room.Status);
|
statusBind.BindTo(room.Status);
|
||||||
typeBind.BindTo(room.Type);
|
typeBind.BindTo(room.Type);
|
||||||
beatmapBind.BindTo(room.Beatmap);
|
roomBeatmap.BindTo(room.Beatmap);
|
||||||
maxParticipantsBind.BindTo(room.MaxParticipants);
|
maxParticipantsBind.BindTo(room.MaxParticipants);
|
||||||
participantsBind.BindTo(room.Participants);
|
participantsBind.BindTo(room.Participants);
|
||||||
}
|
}
|
||||||
@ -104,10 +109,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
Masking = true,
|
Masking = true,
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
cover = new UpdateableBeatmapSetCover
|
background = new UpdateableBeatmapBackgroundSprite { RelativeSizeAxes = Axes.Both },
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both,
|
|
||||||
},
|
|
||||||
new Box
|
new Box
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
@ -207,9 +209,11 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
maxParticipantsBind.ValueChanged += m => participantCount.Max = m;
|
maxParticipantsBind.ValueChanged += m => participantCount.Max = m;
|
||||||
statusBind.ValueChanged += displayStatus;
|
statusBind.ValueChanged += displayStatus;
|
||||||
|
|
||||||
beatmapBind.ValueChanged += b =>
|
background.Beatmap.BindTo(beatmap);
|
||||||
|
|
||||||
|
roomBeatmap.ValueChanged += b =>
|
||||||
{
|
{
|
||||||
cover.BeatmapSet = b?.BeatmapSet;
|
beatmap.Value = beatmaps.GetWorkingBeatmap(b);
|
||||||
beatmapTypeInfo.Beatmap = b;
|
beatmapTypeInfo.Beatmap = b;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -243,7 +247,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
{
|
{
|
||||||
if (Room == null)
|
if (Room == null)
|
||||||
{
|
{
|
||||||
cover.BeatmapSet = null;
|
beatmap.Value = null;
|
||||||
participantsFlow.FadeOut(transition_duration);
|
participantsFlow.FadeOut(transition_duration);
|
||||||
participantCount.FadeOut(transition_duration);
|
participantCount.FadeOut(transition_duration);
|
||||||
beatmapTypeInfo.FadeOut(transition_duration);
|
beatmapTypeInfo.FadeOut(transition_duration);
|
||||||
@ -261,7 +265,7 @@ namespace osu.Game.Screens.Multi.Components
|
|||||||
participantInfo.FadeIn(transition_duration);
|
participantInfo.FadeIn(transition_duration);
|
||||||
|
|
||||||
statusBind.TriggerChange();
|
statusBind.TriggerChange();
|
||||||
beatmapBind.TriggerChange();
|
roomBeatmap.TriggerChange();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Configuration;
|
||||||
using osu.Framework.Extensions.Color4Extensions;
|
using osu.Framework.Extensions.Color4Extensions;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Colour;
|
using osu.Framework.Graphics.Colour;
|
||||||
@ -24,16 +25,12 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
{
|
{
|
||||||
public const float HEIGHT = 200;
|
public const float HEIGHT = 200;
|
||||||
|
|
||||||
|
public readonly IBindable<WorkingBeatmap> Beatmap = new Bindable<WorkingBeatmap>();
|
||||||
|
|
||||||
private readonly Box tabStrip;
|
private readonly Box tabStrip;
|
||||||
private readonly UpdateableBeatmapSetCover cover;
|
|
||||||
|
|
||||||
public readonly PageTabControl<MatchHeaderPage> Tabs;
|
public readonly PageTabControl<MatchHeaderPage> Tabs;
|
||||||
|
|
||||||
public BeatmapSetInfo BeatmapSet
|
|
||||||
{
|
|
||||||
set => cover.BeatmapSet = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Action OnRequestSelectBeatmap;
|
public Action OnRequestSelectBeatmap;
|
||||||
|
|
||||||
public Header()
|
public Header()
|
||||||
@ -42,12 +39,14 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
Height = HEIGHT;
|
Height = HEIGHT;
|
||||||
|
|
||||||
BeatmapSelectButton beatmapButton;
|
BeatmapSelectButton beatmapButton;
|
||||||
|
UpdateableBeatmapBackgroundSprite background;
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
cover = new UpdateableBeatmapSetCover
|
new Container
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Masking = true,
|
Masking = true,
|
||||||
|
Child = background = new UpdateableBeatmapBackgroundSprite { RelativeSizeAxes = Axes.Both }
|
||||||
},
|
},
|
||||||
new Box
|
new Box
|
||||||
{
|
{
|
||||||
@ -90,6 +89,8 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
};
|
};
|
||||||
|
|
||||||
beatmapButton.Action = () => OnRequestSelectBeatmap?.Invoke();
|
beatmapButton.Action = () => OnRequestSelectBeatmap?.Invoke();
|
||||||
|
|
||||||
|
background.Beatmap.BindTo(Beatmap);
|
||||||
}
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Configuration;
|
using osu.Framework.Configuration;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
@ -22,19 +23,24 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
private readonly Bindable<RoomStatus> statusBind = new Bindable<RoomStatus>();
|
||||||
private readonly Bindable<RoomAvailability> availabilityBind = new Bindable<RoomAvailability>();
|
private readonly Bindable<RoomAvailability> availabilityBind = new Bindable<RoomAvailability>();
|
||||||
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
private readonly Bindable<GameType> typeBind = new Bindable<GameType>();
|
||||||
private readonly Bindable<BeatmapInfo> beatmapBind = new Bindable<BeatmapInfo>();
|
|
||||||
private readonly Bindable<int?> maxParticipantsBind = new Bindable<int?>();
|
private readonly Bindable<int?> maxParticipantsBind = new Bindable<int?>();
|
||||||
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
private readonly Bindable<IEnumerable<User>> participantsBind = new Bindable<IEnumerable<User>>();
|
||||||
|
|
||||||
|
private readonly Bindable<BeatmapInfo> roomBeatmap = new Bindable<BeatmapInfo>();
|
||||||
|
|
||||||
protected override Container<Drawable> TransitionContent => participants;
|
protected override Container<Drawable> TransitionContent => participants;
|
||||||
|
|
||||||
public override string Title => room.Name.Value;
|
public override string Title => room.Name.Value;
|
||||||
|
|
||||||
public override string ShortTitle => "room";
|
public override string ShortTitle => "room";
|
||||||
|
|
||||||
|
[Resolved]
|
||||||
|
private BeatmapManager beatmapManager { get; set; }
|
||||||
|
|
||||||
public Match(Room room)
|
public Match(Room room)
|
||||||
{
|
{
|
||||||
this.room = room;
|
this.room = room;
|
||||||
|
|
||||||
Header header;
|
Header header;
|
||||||
RoomSettingsOverlay settings;
|
RoomSettingsOverlay settings;
|
||||||
Info info;
|
Info info;
|
||||||
@ -68,13 +74,9 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
};
|
};
|
||||||
|
|
||||||
header.OnRequestSelectBeatmap = () => Push(new MatchSongSelect());
|
header.OnRequestSelectBeatmap = () => Push(new MatchSongSelect());
|
||||||
|
header.Beatmap.BindTo(Beatmap);
|
||||||
|
|
||||||
beatmapBind.BindTo(room.Beatmap);
|
roomBeatmap.BindValueChanged(b => info.Beatmap = b, true);
|
||||||
beatmapBind.BindValueChanged(b =>
|
|
||||||
{
|
|
||||||
header.BeatmapSet = b?.BeatmapSet;
|
|
||||||
info.Beatmap = b;
|
|
||||||
}, true);
|
|
||||||
|
|
||||||
header.Tabs.Current.ValueChanged += t =>
|
header.Tabs.Current.ValueChanged += t =>
|
||||||
{
|
{
|
||||||
@ -110,5 +112,13 @@ namespace osu.Game.Screens.Multi.Screens.Match
|
|||||||
participantsBind.BindTo(room.Participants);
|
participantsBind.BindTo(room.Participants);
|
||||||
participantsBind.BindValueChanged(p => participants.Users = p, true);
|
participantsBind.BindValueChanged(p => participants.Users = p, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
roomBeatmap.BindTo(room.Beatmap);
|
||||||
|
roomBeatmap.BindValueChanged(b => Beatmap.Value = beatmapManager.GetWorkingBeatmap(room.Beatmap.Value), true);
|
||||||
|
Beatmap.BindValueChanged(b => roomBeatmap.Value = b.BeatmapInfo);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user