1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-06 19:57:24 +08:00
osu-lazer/osu.Game.Tournament/Screens/Editors/SeedingEditorScreen.cs

282 lines
11 KiB
C#
Raw Normal View History

2020-03-03 17:12:42 +08:00
// 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.
2022-06-17 15:37:17 +08:00
#nullable disable
2020-03-03 17:12:42 +08:00
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Bindables;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
using osu.Game.Graphics;
using osu.Game.Online.API;
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2020-03-03 17:12:42 +08:00
using osu.Game.Overlays.Settings;
using osu.Game.Tournament.Components;
using osu.Game.Tournament.Models;
using osuTK;
namespace osu.Game.Tournament.Screens.Editors
{
2022-11-24 13:32:20 +08:00
public partial class SeedingEditorScreen : TournamentEditorScreen<SeedingEditorScreen.SeedingResultRow, SeedingResult>
2020-03-03 17:12:42 +08:00
{
private readonly TournamentTeam team;
protected override BindableList<SeedingResult> Storage => team.SeedingResults;
public SeedingEditorScreen(TournamentTeam team, TournamentScreen parentScreen)
: base(parentScreen)
2020-03-03 17:12:42 +08:00
{
this.team = team;
}
2022-11-24 13:32:20 +08:00
public partial class SeedingResultRow : CompositeDrawable, IModelBacked<SeedingResult>
2020-03-03 17:12:42 +08:00
{
public SeedingResult Model { get; }
public SeedingResultRow(TournamentTeam team, SeedingResult round)
2020-03-03 17:12:42 +08:00
{
Model = round;
Masking = true;
CornerRadius = 10;
SeedingBeatmapEditor beatmapEditor = new SeedingBeatmapEditor(round)
{
Width = 0.95f
};
InternalChildren = new Drawable[]
{
new Box
{
Colour = OsuColour.Gray(0.1f),
RelativeSizeAxes = Axes.Both,
},
new FillFlowContainer
{
Margin = new MarginPadding(5),
Padding = new MarginPadding { Right = 160 },
Spacing = new Vector2(5),
Direction = FillDirection.Full,
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Children = new Drawable[]
{
new SettingsTextBox
{
LabelText = "Mod",
Width = 0.33f,
Current = Model.Mod
2020-03-03 17:12:42 +08:00
},
new SettingsSlider<int>
{
LabelText = "Seed",
Width = 0.33f,
Current = Model.Seed
2020-03-03 17:12:42 +08:00
},
new SettingsButton
{
Width = 0.2f,
Margin = new MarginPadding(10),
Text = "Add beatmap",
Action = () => beatmapEditor.CreateNew()
},
beatmapEditor
}
},
new DangerousSettingsButton
{
Anchor = Anchor.CentreRight,
Origin = Anchor.CentreRight,
RelativeSizeAxes = Axes.None,
Width = 150,
Text = "Delete result",
2020-03-03 17:12:42 +08:00
Action = () =>
{
Expire();
team.SeedingResults.Remove(Model);
},
}
};
RelativeSizeAxes = Axes.X;
AutoSizeAxes = Axes.Y;
}
2022-11-24 13:32:20 +08:00
public partial class SeedingBeatmapEditor : CompositeDrawable
2020-03-03 17:12:42 +08:00
{
private readonly SeedingResult round;
private readonly FillFlowContainer flow;
public SeedingBeatmapEditor(SeedingResult round)
{
this.round = round;
RelativeSizeAxes = Axes.X;
AutoSizeAxes = Axes.Y;
InternalChild = flow = new FillFlowContainer
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
ChildrenEnumerable = round.Beatmaps.Select(p => new SeedingBeatmapRow(round, p))
};
}
public void CreateNew()
{
var user = new SeedingBeatmap();
round.Beatmaps.Add(user);
flow.Add(new SeedingBeatmapRow(round, user));
}
2022-11-24 13:32:20 +08:00
public partial class SeedingBeatmapRow : CompositeDrawable
2020-03-03 17:12:42 +08:00
{
private readonly SeedingResult result;
public SeedingBeatmap Model { get; }
[Resolved]
protected IAPIProvider API { get; private set; }
private readonly Bindable<int?> beatmapId = new Bindable<int?>();
2020-03-03 17:12:42 +08:00
private readonly Bindable<string> score = new Bindable<string>(string.Empty);
2020-03-03 17:12:42 +08:00
private readonly Container drawableContainer;
public SeedingBeatmapRow(SeedingResult result, SeedingBeatmap beatmap)
{
this.result = result;
Model = beatmap;
Margin = new MarginPadding(10);
RelativeSizeAxes = Axes.X;
AutoSizeAxes = Axes.Y;
Masking = true;
CornerRadius = 5;
InternalChildren = new Drawable[]
{
new Box
{
Colour = OsuColour.Gray(0.2f),
RelativeSizeAxes = Axes.Both,
},
new FillFlowContainer
{
Margin = new MarginPadding(5),
Padding = new MarginPadding { Right = 160 },
Spacing = new Vector2(5),
Direction = FillDirection.Horizontal,
AutoSizeAxes = Axes.Both,
Children = new Drawable[]
{
new SettingsNumberBox
{
LabelText = "Beatmap ID",
RelativeSizeAxes = Axes.None,
Width = 200,
Current = beatmapId,
2020-03-03 17:12:42 +08:00
},
new SettingsSlider<int>
{
LabelText = "Seed",
RelativeSizeAxes = Axes.None,
Width = 200,
Current = beatmap.Seed
2020-03-03 17:12:42 +08:00
},
new SettingsTextBox
{
LabelText = "Score",
RelativeSizeAxes = Axes.None,
Width = 200,
Current = score,
2020-03-03 17:12:42 +08:00
},
drawableContainer = new Container
{
Size = new Vector2(100, 70),
},
}
},
new DangerousSettingsButton
{
Anchor = Anchor.CentreRight,
Origin = Anchor.CentreRight,
RelativeSizeAxes = Axes.None,
Width = 150,
Text = "Delete Beatmap",
Action = () =>
{
Expire();
result.Beatmaps.Remove(beatmap);
},
}
};
}
[BackgroundDependencyLoader]
2022-01-15 08:06:39 +08:00
private void load()
2020-03-03 17:12:42 +08:00
{
beatmapId.Value = Model.ID;
beatmapId.BindValueChanged(id =>
2020-03-03 17:12:42 +08:00
{
Model.ID = id.NewValue ?? 0;
2020-03-03 17:12:42 +08:00
if (id.NewValue != id.OldValue)
Model.Beatmap = null;
2020-03-03 17:12:42 +08:00
if (Model.Beatmap != null)
2020-03-03 17:12:42 +08:00
{
updatePanel();
return;
}
var req = new GetBeatmapRequest(new APIBeatmap { OnlineID = Model.ID });
2020-03-03 17:12:42 +08:00
req.Success += res => Schedule(() =>
2020-03-03 17:12:42 +08:00
{
Model.Beatmap = new TournamentBeatmap(res);
2020-03-03 17:12:42 +08:00
updatePanel();
});
2020-03-03 17:12:42 +08:00
req.Failure += _ => Schedule(() =>
2020-03-03 17:12:42 +08:00
{
Model.Beatmap = null;
2020-03-03 17:12:42 +08:00
updatePanel();
});
2020-03-03 17:12:42 +08:00
API.Queue(req);
}, true);
score.Value = Model.Score.ToString();
score.BindValueChanged(str => long.TryParse(str.NewValue, out Model.Score));
}
private void updatePanel()
{
drawableContainer.Clear();
if (Model.Beatmap != null)
2020-03-03 17:12:42 +08:00
{
drawableContainer.Child = new TournamentBeatmapPanel(Model.Beatmap, result.Mod.Value)
2020-03-03 17:12:42 +08:00
{
Anchor = Anchor.CentreLeft,
Origin = Anchor.CentreLeft,
Width = 300
};
}
}
}
}
}
protected override SeedingResultRow CreateDrawable(SeedingResult model) => new SeedingResultRow(team, model);
2020-03-03 17:12:42 +08:00
}
}