mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 02:43:19 +08:00
Add and wire up all sliderbar-based options
This commit is contained in:
parent
3aefa4d6a5
commit
92cf841589
@ -19,14 +19,11 @@ namespace osu.Game.Overlays.Options.Audio
|
||||
{
|
||||
Children = new Drawable[]
|
||||
{
|
||||
// TODO: bindable int crap
|
||||
/*
|
||||
new OptionsSlider
|
||||
new OptionsSlider<int>
|
||||
{
|
||||
Label = "Universal Offset",
|
||||
Bindable = (BindableDouble)config.GetBindable<double>(OsuConfig.Offset)
|
||||
Bindable = (BindableInt)config.GetBindable<int>(OsuConfig.Offset)
|
||||
},
|
||||
*/
|
||||
new OsuButton
|
||||
{
|
||||
RelativeSizeAxes = Axes.X,
|
||||
|
@ -20,9 +20,9 @@ namespace osu.Game.Overlays.Options.Audio
|
||||
{
|
||||
Children = new Drawable[]
|
||||
{
|
||||
new OptionsSlider { Label = "Master", Bindable = audio.Volume },
|
||||
new OptionsSlider { Label = "Effect", Bindable = audio.VolumeSample },
|
||||
new OptionsSlider { Label = "Music", Bindable = audio.VolumeTrack },
|
||||
new OptionsSlider<double> { Label = "Master", Bindable = audio.Volume },
|
||||
new OptionsSlider<double> { Label = "Effect", Bindable = audio.VolumeSample },
|
||||
new OptionsSlider<double> { Label = "Music", Bindable = audio.VolumeTrack },
|
||||
new CheckBoxOption
|
||||
{
|
||||
LabelText = "Ignore beatmap hitsounds",
|
||||
|
@ -20,17 +20,14 @@ namespace osu.Game.Overlays.Options.Gameplay
|
||||
{
|
||||
Children = new Drawable[]
|
||||
{
|
||||
// TODO: bindable int stuff
|
||||
/*
|
||||
new OptionsSlider
|
||||
new OptionsSlider<int>
|
||||
{
|
||||
Label = "Background dim",
|
||||
Bindable = (BindableDouble)config.GetBindable<double>(OsuConfig.DimLevel)
|
||||
Bindable = (BindableInt)config.GetBindable<int>(OsuConfig.DimLevel)
|
||||
},
|
||||
*/
|
||||
new SpriteText { Text = "Progress display: TODO dropdown" },
|
||||
new SpriteText { Text = "Score meter type: TODO dropdown" },
|
||||
new OptionsSlider
|
||||
new OptionsSlider<double>
|
||||
{
|
||||
Label = "Score meter size",
|
||||
Bindable = (BindableDouble)config.GetBindable<double>(OsuConfig.ScoreMeterScale)
|
||||
|
@ -15,37 +15,35 @@ namespace osu.Game.Overlays.Options.Gameplay
|
||||
{
|
||||
protected override string Header => "Song Select";
|
||||
|
||||
//private BindableInt starMinimum, starMaximum;
|
||||
//private StarCounter counterMin, counterMax;
|
||||
private BindableInt starMinimum, starMaximum;
|
||||
private StarCounter counterMin, counterMax;
|
||||
|
||||
[BackgroundDependencyLoader]
|
||||
private void load(OsuConfigManager config)
|
||||
{
|
||||
// TODO: Deal with bindable ints
|
||||
/*
|
||||
starMinimum = config.GetBindable<int>(OsuConfig.DisplayStarsMinimum);
|
||||
starMaximum = config.GetBindable<int>(OsuConfig.DisplayStarsMaximum);
|
||||
starMinimum = (BindableInt)config.GetBindable<int>(OsuConfig.DisplayStarsMinimum);
|
||||
starMaximum = (BindableInt)config.GetBindable<int>(OsuConfig.DisplayStarsMaximum);
|
||||
Children = new Drawable[]
|
||||
{
|
||||
new OptionsSlider { Label = "Display beatmaps from", Bindable = starMinimum },
|
||||
new OptionsSlider<int> { Label = "Display beatmaps from", Bindable = starMinimum },
|
||||
counterMin = new StarCounter { Count = starMinimum.Value },
|
||||
new OptionsSlider { Label = "up to", Bindable = starMaximum },
|
||||
new OptionsSlider<int> { Label = "up to", Bindable = starMaximum },
|
||||
counterMax = new StarCounter { Count = starMaximum.Value },
|
||||
};
|
||||
starMinimum.ValueChanged += starValueChanged;
|
||||
starMaximum.ValueChanged += starValueChanged;*/
|
||||
starMaximum.ValueChanged += starValueChanged;
|
||||
}
|
||||
|
||||
private void starValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
//counterMin.Count = starMinimum.Value;
|
||||
//counterMax.Count = starMaximum.Value;
|
||||
counterMin.Count = starMinimum.Value;
|
||||
counterMax.Count = starMaximum.Value;
|
||||
}
|
||||
|
||||
protected override void Dispose(bool isDisposing)
|
||||
{
|
||||
//starMinimum.ValueChanged -= starValueChanged;
|
||||
//starMaximum.ValueChanged -= starValueChanged;
|
||||
starMinimum.ValueChanged -= starValueChanged;
|
||||
starMaximum.ValueChanged -= starValueChanged;
|
||||
base.Dispose(isDisposing);
|
||||
}
|
||||
}
|
||||
|
@ -31,19 +31,16 @@ namespace osu.Game.Overlays.Options.Graphics
|
||||
LabelText = "Letterboxing",
|
||||
Bindable = config.GetBindable<bool>(OsuConfig.Letterboxing),
|
||||
},
|
||||
// TODO: deal with bindable ints
|
||||
/*
|
||||
new OptionsSlider
|
||||
new OptionsSlider<int>
|
||||
{
|
||||
Label = "Horizontal position",
|
||||
Bindable = config.GetBindable<int>(OsuConfig.LetterboxPositionX)
|
||||
Bindable = (BindableInt)config.GetBindable<int>(OsuConfig.LetterboxPositionX)
|
||||
},
|
||||
new OptionsSlider
|
||||
new OptionsSlider<int>
|
||||
{
|
||||
Label = "Vertical position",
|
||||
Bindable = config.GetBindable<int>(OsuConfig.LetterboxPositionY)
|
||||
Bindable = (BindableInt)config.GetBindable<int>(OsuConfig.LetterboxPositionY)
|
||||
},
|
||||
*/
|
||||
};
|
||||
}
|
||||
}
|
||||
|
@ -9,9 +9,10 @@ using osu.Framework.Graphics.UserInterface;
|
||||
|
||||
namespace osu.Game.Overlays.Options
|
||||
{
|
||||
public class OptionsSlider : FlowContainer
|
||||
public class OptionsSlider<T> : FlowContainer where T : struct,
|
||||
IComparable, IFormattable, IConvertible, IComparable<T>, IEquatable<T>
|
||||
{
|
||||
private SliderBar slider;
|
||||
private SliderBar<T> slider;
|
||||
private SpriteText text;
|
||||
|
||||
public string Label
|
||||
@ -24,7 +25,7 @@ namespace osu.Game.Overlays.Options
|
||||
}
|
||||
}
|
||||
|
||||
public BindableDouble Bindable
|
||||
public BindableNumber<T> Bindable
|
||||
{
|
||||
get { return slider.Bindable; }
|
||||
set { slider.Bindable = value; }
|
||||
@ -38,7 +39,7 @@ namespace osu.Game.Overlays.Options
|
||||
Children = new Drawable[]
|
||||
{
|
||||
text = new SpriteText { Alpha = 0 },
|
||||
slider = new SliderBar
|
||||
slider = new SliderBar<T>
|
||||
{
|
||||
Margin = new MarginPadding { Top = 5 },
|
||||
Height = 10,
|
||||
|
Loading…
Reference in New Issue
Block a user