mirror of
https://github.com/ppy/osu.git
synced 2025-01-07 22:22:59 +08:00
Make Room.DifficultyRange
non-bindable
This commit is contained in:
parent
487a010b12
commit
c4f8fd1832
@ -20,7 +20,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
{
|
{
|
||||||
SelectedRoom.Value = new Room();
|
SelectedRoom.Value = new Room();
|
||||||
|
|
||||||
Child = new StarRatingRangeDisplay
|
Child = new StarRatingRangeDisplay(SelectedRoom.Value)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre
|
Origin = Anchor.Centre
|
||||||
|
@ -164,6 +164,15 @@ namespace osu.Game.Online.Rooms
|
|||||||
set => SetField(ref playlistItemStats, value);
|
set => SetField(ref playlistItemStats, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Describes the range of difficulty of the room.
|
||||||
|
/// </summary>
|
||||||
|
public RoomDifficultyRange? DifficultyRange
|
||||||
|
{
|
||||||
|
get => difficultyRange;
|
||||||
|
set => SetField(ref difficultyRange, value);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The playlist queueing mode. Only valid for multiplayer rooms.
|
/// The playlist queueing mode. Only valid for multiplayer rooms.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -270,6 +279,9 @@ namespace osu.Game.Online.Rooms
|
|||||||
[JsonProperty("playlist_item_stats")]
|
[JsonProperty("playlist_item_stats")]
|
||||||
private RoomPlaylistItemStats? playlistItemStats;
|
private RoomPlaylistItemStats? playlistItemStats;
|
||||||
|
|
||||||
|
[JsonProperty("difficulty_range")]
|
||||||
|
private RoomDifficultyRange? difficultyRange;
|
||||||
|
|
||||||
[JsonConverter(typeof(SnakeCaseStringEnumConverter))]
|
[JsonConverter(typeof(SnakeCaseStringEnumConverter))]
|
||||||
[JsonProperty("type")]
|
[JsonProperty("type")]
|
||||||
private MatchType type;
|
private MatchType type;
|
||||||
@ -300,10 +312,6 @@ namespace osu.Game.Online.Rooms
|
|||||||
[JsonProperty("playlist")]
|
[JsonProperty("playlist")]
|
||||||
public readonly BindableList<PlaylistItem> Playlist = new BindableList<PlaylistItem>();
|
public readonly BindableList<PlaylistItem> Playlist = new BindableList<PlaylistItem>();
|
||||||
|
|
||||||
[JsonProperty("difficulty_range")]
|
|
||||||
[Cached]
|
|
||||||
public readonly Bindable<RoomDifficultyRange> DifficultyRange = new Bindable<RoomDifficultyRange>();
|
|
||||||
|
|
||||||
[Cached]
|
[Cached]
|
||||||
[JsonProperty("current_user_score")]
|
[JsonProperty("current_user_score")]
|
||||||
public readonly Bindable<PlaylistAggregateScore> UserScore = new Bindable<PlaylistAggregateScore>();
|
public readonly Bindable<PlaylistAggregateScore> UserScore = new Bindable<PlaylistAggregateScore>();
|
||||||
@ -340,7 +348,7 @@ namespace osu.Game.Online.Rooms
|
|||||||
UserScore.Value = other.UserScore.Value;
|
UserScore.Value = other.UserScore.Value;
|
||||||
QueueMode = other.QueueMode;
|
QueueMode = other.QueueMode;
|
||||||
AutoStartDuration = other.AutoStartDuration;
|
AutoStartDuration = other.AutoStartDuration;
|
||||||
DifficultyRange.Value = other.DifficultyRange.Value;
|
DifficultyRange = other.DifficultyRange;
|
||||||
PlaylistItemStats = other.PlaylistItemStats;
|
PlaylistItemStats = other.PlaylistItemStats;
|
||||||
CurrentPlaylistItem = other.CurrentPlaylistItem;
|
CurrentPlaylistItem = other.CurrentPlaylistItem;
|
||||||
AutoSkip = other.AutoSkip;
|
AutoSkip = other.AutoSkip;
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
// 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.
|
||||||
|
|
||||||
#nullable disable
|
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.ComponentModel;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
@ -13,22 +12,27 @@ using osu.Framework.Utils;
|
|||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
using osu.Game.Beatmaps.Drawables;
|
using osu.Game.Beatmaps.Drawables;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
|
using osu.Game.Online.Rooms;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
|
using Container = osu.Framework.Graphics.Containers.Container;
|
||||||
|
|
||||||
namespace osu.Game.Screens.OnlinePlay.Components
|
namespace osu.Game.Screens.OnlinePlay.Components
|
||||||
{
|
{
|
||||||
public partial class StarRatingRangeDisplay : OnlinePlayComposite
|
public partial class StarRatingRangeDisplay : OnlinePlayComposite
|
||||||
{
|
{
|
||||||
|
private readonly Room room;
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private OsuColour colours { get; set; }
|
private OsuColour colours { get; set; } = null!;
|
||||||
|
|
||||||
private StarRatingDisplay minDisplay;
|
private StarRatingDisplay minDisplay = null!;
|
||||||
private Drawable minBackground;
|
private Drawable minBackground = null!;
|
||||||
private StarRatingDisplay maxDisplay;
|
private StarRatingDisplay maxDisplay = null!;
|
||||||
private Drawable maxBackground;
|
private Drawable maxBackground = null!;
|
||||||
|
|
||||||
public StarRatingRangeDisplay()
|
public StarRatingRangeDisplay(Room room)
|
||||||
{
|
{
|
||||||
|
this.room = room;
|
||||||
AutoSizeAxes = Axes.Both;
|
AutoSizeAxes = Axes.Both;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,8 +80,16 @@ namespace osu.Game.Screens.OnlinePlay.Components
|
|||||||
{
|
{
|
||||||
base.LoadComplete();
|
base.LoadComplete();
|
||||||
|
|
||||||
DifficultyRange.BindValueChanged(_ => updateRange());
|
Playlist.BindCollectionChanged((_, _) => updateRange());
|
||||||
Playlist.BindCollectionChanged((_, _) => updateRange(), true);
|
|
||||||
|
room.PropertyChanged += onRoomPropertyChanged;
|
||||||
|
updateRange();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onRoomPropertyChanged(object? sender, PropertyChangedEventArgs e)
|
||||||
|
{
|
||||||
|
if (e.PropertyName == nameof(Room.DifficultyRange))
|
||||||
|
updateRange();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateRange()
|
private void updateRange()
|
||||||
@ -85,11 +97,11 @@ namespace osu.Game.Screens.OnlinePlay.Components
|
|||||||
StarDifficulty minDifficulty;
|
StarDifficulty minDifficulty;
|
||||||
StarDifficulty maxDifficulty;
|
StarDifficulty maxDifficulty;
|
||||||
|
|
||||||
if (DifficultyRange.Value != null && Playlist.Count == 0)
|
if (room.DifficultyRange != null && Playlist.Count == 0)
|
||||||
{
|
{
|
||||||
// When Playlist is empty (in lounge) we take retrieved range
|
// When Playlist is empty (in lounge) we take retrieved range
|
||||||
minDifficulty = new StarDifficulty(DifficultyRange.Value.Min, 0);
|
minDifficulty = new StarDifficulty(room.DifficultyRange.Min, 0);
|
||||||
maxDifficulty = new StarDifficulty(DifficultyRange.Value.Max, 0);
|
maxDifficulty = new StarDifficulty(room.DifficultyRange.Max, 0);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -107,5 +119,11 @@ namespace osu.Game.Screens.OnlinePlay.Components
|
|||||||
minBackground.Colour = colours.ForStarDifficulty(minDifficulty.Stars);
|
minBackground.Colour = colours.ForStarDifficulty(minDifficulty.Stars);
|
||||||
maxBackground.Colour = colours.ForStarDifficulty(maxDifficulty.Stars);
|
maxBackground.Colour = colours.ForStarDifficulty(maxDifficulty.Stars);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void Dispose(bool isDisposing)
|
||||||
|
{
|
||||||
|
base.Dispose(isDisposing);
|
||||||
|
room.PropertyChanged -= onRoomPropertyChanged;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -360,7 +360,7 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
|
|||||||
Anchor = Anchor.CentreLeft,
|
Anchor = Anchor.CentreLeft,
|
||||||
Origin = Anchor.CentreLeft,
|
Origin = Anchor.CentreLeft,
|
||||||
},
|
},
|
||||||
new StarRatingRangeDisplay
|
new StarRatingRangeDisplay(Room)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.CentreLeft,
|
Anchor = Anchor.CentreLeft,
|
||||||
Origin = Anchor.CentreLeft,
|
Origin = Anchor.CentreLeft,
|
||||||
|
@ -17,9 +17,6 @@ namespace osu.Game.Screens.OnlinePlay
|
|||||||
[Resolved(typeof(Room))]
|
[Resolved(typeof(Room))]
|
||||||
protected BindableList<PlaylistItem> Playlist { get; private set; } = null!;
|
protected BindableList<PlaylistItem> Playlist { get; private set; } = null!;
|
||||||
|
|
||||||
[Resolved(typeof(Room))]
|
|
||||||
protected Bindable<Room.RoomDifficultyRange> DifficultyRange { get; private set; } = null!;
|
|
||||||
|
|
||||||
[Resolved(typeof(Room))]
|
[Resolved(typeof(Room))]
|
||||||
protected BindableList<APIUser> RecentParticipants { get; private set; } = null!;
|
protected BindableList<APIUser> RecentParticipants { get; private set; } = null!;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user