mirror of
https://github.com/ppy/osu.git
synced 2024-12-14 20:13:21 +08:00
Handle changes to SettingSource
skin element settings
This commit is contained in:
parent
e5f62b0d2e
commit
7445814fc6
@ -2,10 +2,13 @@
|
||||
// See the LICENCE file in the repository root for full licence text.
|
||||
|
||||
using System.Linq;
|
||||
using osu.Framework.Allocation;
|
||||
using osu.Framework.Graphics;
|
||||
using osu.Framework.Graphics.Containers;
|
||||
using osu.Game.Configuration;
|
||||
using osu.Game.Localisation;
|
||||
using osu.Game.Overlays.Settings;
|
||||
using osu.Game.Screens.Edit;
|
||||
using osu.Game.Screens.Edit.Components;
|
||||
using osuTK;
|
||||
|
||||
@ -13,19 +16,41 @@ namespace osu.Game.Overlays.SkinEditor
|
||||
{
|
||||
internal partial class SkinSettingsToolbox : EditorSidebarSection
|
||||
{
|
||||
[Resolved]
|
||||
private IEditorChangeHandler? changeHandler { get; set; }
|
||||
|
||||
protected override Container<Drawable> Content { get; }
|
||||
|
||||
private readonly Drawable component;
|
||||
|
||||
public SkinSettingsToolbox(Drawable component)
|
||||
: base(SkinEditorStrings.Settings(component.GetType().Name))
|
||||
{
|
||||
this.component = component;
|
||||
|
||||
base.Content.Add(Content = new FillFlowContainer
|
||||
{
|
||||
RelativeSizeAxes = Axes.X,
|
||||
AutoSizeAxes = Axes.Y,
|
||||
Direction = FillDirection.Vertical,
|
||||
Spacing = new Vector2(10),
|
||||
Children = component.CreateSettingsControls().ToArray()
|
||||
});
|
||||
}
|
||||
|
||||
[BackgroundDependencyLoader]
|
||||
private void load()
|
||||
{
|
||||
var controls = component.CreateSettingsControls().ToArray();
|
||||
|
||||
Content.AddRange(controls);
|
||||
|
||||
// track any changes to update undo states.
|
||||
foreach (var c in controls.OfType<ISettingsItem>())
|
||||
{
|
||||
// TODO: SettingChanged is called too often for cases like SettingsTextBox and SettingsSlider.
|
||||
// We will want to expose a SettingCommitted or similar to make this work better.
|
||||
c.SettingChanged += () => changeHandler?.SaveState();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user