mirror of
https://github.com/ppy/osu.git
synced 2025-01-19 10:03:21 +08:00
Use CMC in the Multiplayer screen
This commit is contained in:
parent
37c1f5a824
commit
d9537017c8
@ -83,7 +83,7 @@ namespace osu.Game.Online.Multiplayer
|
||||
/// The position of this <see cref="Room"/> in the list. This is not read from or written to the API.
|
||||
/// </summary>
|
||||
[JsonIgnore]
|
||||
public int Position = -1;
|
||||
public Bindable<int> Position { get; private set; } = new Bindable<int>(-1);
|
||||
|
||||
public void CopyFrom(Room other)
|
||||
{
|
||||
|
@ -149,6 +149,15 @@ namespace osu.Game.Screens.Multi
|
||||
isIdle.BindTo(idleTracker.IsIdle);
|
||||
}
|
||||
|
||||
private CachedModelDependencyContainer<Room> dependencies;
|
||||
|
||||
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
|
||||
{
|
||||
dependencies = new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent));
|
||||
dependencies.Model.BindTo(roomManager.CurrentRoom);
|
||||
return dependencies;
|
||||
}
|
||||
|
||||
protected override void LoadComplete()
|
||||
{
|
||||
base.LoadComplete();
|
||||
|
@ -23,7 +23,7 @@ namespace osu.Game.Screens.Multi
|
||||
private readonly BindableList<Room> rooms = new BindableList<Room>();
|
||||
public IBindableList<Room> Rooms => rooms;
|
||||
|
||||
private Room currentRoom;
|
||||
public readonly Bindable<Room> CurrentRoom = new Bindable<Room>();
|
||||
|
||||
[Resolved]
|
||||
private APIAccess api { get; set; }
|
||||
@ -77,7 +77,7 @@ namespace osu.Game.Screens.Multi
|
||||
currentJoinRoomRequest = new JoinRoomRequest(room, api.LocalUser.Value);
|
||||
currentJoinRoomRequest.Success += () =>
|
||||
{
|
||||
currentRoom = room;
|
||||
CurrentRoom.Value = room;
|
||||
onSuccess?.Invoke(room);
|
||||
};
|
||||
|
||||
@ -92,11 +92,11 @@ namespace osu.Game.Screens.Multi
|
||||
|
||||
public void PartRoom()
|
||||
{
|
||||
if (currentRoom == null)
|
||||
if (CurrentRoom.Value == null)
|
||||
return;
|
||||
|
||||
api.Queue(new PartRoomRequest(currentRoom, api.LocalUser.Value));
|
||||
currentRoom = null;
|
||||
api.Queue(new PartRoomRequest(CurrentRoom.Value, api.LocalUser.Value));
|
||||
CurrentRoom.Value = null;
|
||||
}
|
||||
|
||||
public void UpdateRooms(List<Room> newRooms)
|
||||
@ -111,7 +111,7 @@ namespace osu.Game.Screens.Multi
|
||||
for (int i = 0; i < newRooms.Count; i++)
|
||||
{
|
||||
var r = newRooms[i];
|
||||
r.Position = i;
|
||||
r.Position.Value = i;
|
||||
|
||||
update(r, r);
|
||||
addRoom(r);
|
||||
|
Loading…
Reference in New Issue
Block a user