mirror of
https://github.com/ppy/osu.git
synced 2025-02-13 15:03:13 +08:00
Merge branch 'master' into add-room-null-check
This commit is contained in:
commit
1d40d88f82
@ -5,7 +5,6 @@ using osu.Framework.Allocation;
|
|||||||
using osu.Framework.Configuration;
|
using osu.Framework.Configuration;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Input;
|
using osu.Framework.Input;
|
||||||
using osu.Framework.Input.Events;
|
|
||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Graphics.UserInterface;
|
using osu.Game.Graphics.UserInterface;
|
||||||
|
|
||||||
@ -78,66 +77,15 @@ namespace osu.Game.Overlays.Settings.Sections.Input
|
|||||||
|
|
||||||
private class SensitivitySetting : SettingsSlider<double, SensitivitySlider>
|
private class SensitivitySetting : SettingsSlider<double, SensitivitySlider>
|
||||||
{
|
{
|
||||||
public override Bindable<double> Bindable
|
|
||||||
{
|
|
||||||
get { return ((SensitivitySlider)Control).Sensitivity; }
|
|
||||||
|
|
||||||
set
|
|
||||||
{
|
|
||||||
BindableDouble doubleValue = (BindableDouble)value;
|
|
||||||
|
|
||||||
// create a second layer of bindable so we can only handle state changes when not being dragged.
|
|
||||||
((SensitivitySlider)Control).Sensitivity = doubleValue;
|
|
||||||
|
|
||||||
// this bindable will still act as the "interactive" bindable displayed during a drag.
|
|
||||||
base.Bindable = new BindableDouble(doubleValue.Value)
|
|
||||||
{
|
|
||||||
Default = doubleValue.Default,
|
|
||||||
MinValue = doubleValue.MinValue,
|
|
||||||
MaxValue = doubleValue.MaxValue
|
|
||||||
};
|
|
||||||
|
|
||||||
// one-way binding to update the sliderbar with changes from external actions.
|
|
||||||
doubleValue.DisabledChanged += disabled => base.Bindable.Disabled = disabled;
|
|
||||||
doubleValue.ValueChanged += newValue => base.Bindable.Value = newValue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public SensitivitySetting()
|
public SensitivitySetting()
|
||||||
{
|
{
|
||||||
KeyboardStep = 0.01f;
|
KeyboardStep = 0.01f;
|
||||||
|
TransferValueOnCommit = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class SensitivitySlider : OsuSliderBar<double>
|
private class SensitivitySlider : OsuSliderBar<double>
|
||||||
{
|
{
|
||||||
public Bindable<double> Sensitivity;
|
|
||||||
|
|
||||||
public SensitivitySlider()
|
|
||||||
{
|
|
||||||
Current.ValueChanged += newValue =>
|
|
||||||
{
|
|
||||||
if (!isDragging && Sensitivity != null)
|
|
||||||
Sensitivity.Value = newValue;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private bool isDragging;
|
|
||||||
|
|
||||||
protected override bool OnDragStart(DragStartEvent e)
|
|
||||||
{
|
|
||||||
isDragging = true;
|
|
||||||
return base.OnDragStart(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override bool OnDragEnd(DragEndEvent e)
|
|
||||||
{
|
|
||||||
isDragging = false;
|
|
||||||
Current.TriggerChange();
|
|
||||||
|
|
||||||
return base.OnDragEnd(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string TooltipText => Current.Disabled ? "Enable raw input to adjust sensitivity" : Current.Value.ToString(@"0.##x");
|
public override string TooltipText => Current.Disabled ? "Enable raw input to adjust sensitivity" : Current.Value.ToString(@"0.##x");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,8 @@ namespace osu.Game.Screens.Multi.Match
|
|||||||
|
|
||||||
MatchChatDisplay chat;
|
MatchChatDisplay chat;
|
||||||
Components.Header header;
|
Components.Header header;
|
||||||
|
Info info;
|
||||||
|
GridContainer bottomRow;
|
||||||
MatchSettingsOverlay settings;
|
MatchSettingsOverlay settings;
|
||||||
|
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
@ -61,10 +63,10 @@ namespace osu.Game.Screens.Multi.Match
|
|||||||
Content = new[]
|
Content = new[]
|
||||||
{
|
{
|
||||||
new Drawable[] { header = new Components.Header(room) { Depth = -1 } },
|
new Drawable[] { header = new Components.Header(room) { Depth = -1 } },
|
||||||
new Drawable[] { new Info(room) { OnStart = onStart } },
|
new Drawable[] { info = new Info(room) { OnStart = onStart } },
|
||||||
new Drawable[]
|
new Drawable[]
|
||||||
{
|
{
|
||||||
new GridContainer
|
bottomRow = new GridContainer
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Content = new[]
|
Content = new[]
|
||||||
@ -109,10 +111,19 @@ namespace osu.Game.Screens.Multi.Match
|
|||||||
header.OnRequestSelectBeatmap = () => Push(new MatchSongSelect { Selected = addPlaylistItem });
|
header.OnRequestSelectBeatmap = () => Push(new MatchSongSelect { Selected = addPlaylistItem });
|
||||||
header.Tabs.Current.ValueChanged += t =>
|
header.Tabs.Current.ValueChanged += t =>
|
||||||
{
|
{
|
||||||
|
const float fade_duration = 500;
|
||||||
if (t is SettingsMatchPage)
|
if (t is SettingsMatchPage)
|
||||||
|
{
|
||||||
settings.Show();
|
settings.Show();
|
||||||
|
info.FadeOut(fade_duration, Easing.OutQuint);
|
||||||
|
bottomRow.FadeOut(fade_duration, Easing.OutQuint);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
settings.Hide();
|
settings.Hide();
|
||||||
|
info.FadeIn(fade_duration, Easing.OutQuint);
|
||||||
|
bottomRow.FadeIn(fade_duration, Easing.OutQuint);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
chat.Exit += Exit;
|
chat.Exit += Exit;
|
||||||
|
Loading…
Reference in New Issue
Block a user