mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 16:12:54 +08:00
rework code logic to make more sense
analysis container creates settings and the settings items are created more nicely also removed use of localized strings because that can be done separately
This commit is contained in:
parent
1ed94e598a
commit
a2b15fcdee
@ -13,6 +13,7 @@ using osu.Game.Beatmaps.Legacy;
|
|||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Overlays.Settings;
|
using osu.Game.Overlays.Settings;
|
||||||
|
using osu.Game.Replays;
|
||||||
using osu.Game.Rulesets.Configuration;
|
using osu.Game.Rulesets.Configuration;
|
||||||
using osu.Game.Rulesets.Difficulty;
|
using osu.Game.Rulesets.Difficulty;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
@ -37,7 +38,6 @@ using osu.Game.Rulesets.Scoring.Legacy;
|
|||||||
using osu.Game.Rulesets.UI;
|
using osu.Game.Rulesets.UI;
|
||||||
using osu.Game.Scoring;
|
using osu.Game.Scoring;
|
||||||
using osu.Game.Screens.Edit.Setup;
|
using osu.Game.Screens.Edit.Setup;
|
||||||
using osu.Game.Screens.Play.PlayerSettings;
|
|
||||||
using osu.Game.Screens.Ranking.Statistics;
|
using osu.Game.Screens.Ranking.Statistics;
|
||||||
using osu.Game.Skinning;
|
using osu.Game.Skinning;
|
||||||
|
|
||||||
@ -361,7 +361,7 @@ namespace osu.Game.Rulesets.Osu
|
|||||||
return adjustedDifficulty;
|
return adjustedDifficulty;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override AnalysisSettings CreateAnalysisSettings(DrawableRuleset drawableRuleset) => new OsuAnalysisSettings(drawableRuleset);
|
public override OsuAnalysisContainer CreateAnalysisContainer(Replay replay, Playfield playfield) => new OsuAnalysisContainer(replay, playfield);
|
||||||
|
|
||||||
public override bool EditorShowScrollSpeed => false;
|
public override bool EditorShowScrollSpeed => false;
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
// 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.
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Bindables;
|
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Lines;
|
using osu.Framework.Graphics.Lines;
|
||||||
using osu.Framework.Graphics.Performance;
|
using osu.Framework.Graphics.Performance;
|
||||||
@ -21,27 +21,33 @@ namespace osu.Game.Rulesets.Osu.UI
|
|||||||
{
|
{
|
||||||
public partial class OsuAnalysisContainer : AnalysisContainer
|
public partial class OsuAnalysisContainer : AnalysisContainer
|
||||||
{
|
{
|
||||||
public Bindable<bool> HitMarkerEnabled = new BindableBool();
|
public new OsuAnalysisSettings AnalysisSettings => (OsuAnalysisSettings)base.AnalysisSettings;
|
||||||
public Bindable<bool> AimMarkersEnabled = new BindableBool();
|
|
||||||
public Bindable<bool> AimLinesEnabled = new BindableBool();
|
protected new OsuPlayfield Playfield => (OsuPlayfield)base.Playfield;
|
||||||
|
|
||||||
protected HitMarkersContainer HitMarkers;
|
protected HitMarkersContainer HitMarkers;
|
||||||
protected AimMarkersContainer AimMarkers;
|
protected AimMarkersContainer AimMarkers;
|
||||||
protected AimLinesContainer AimLines;
|
protected AimLinesContainer AimLines;
|
||||||
|
|
||||||
public OsuAnalysisContainer(Replay replay)
|
public OsuAnalysisContainer(Replay replay, Playfield playfield)
|
||||||
: base(replay)
|
: base(replay, playfield)
|
||||||
{
|
{
|
||||||
InternalChildren = new Drawable[]
|
InternalChildren = new Drawable[]
|
||||||
{
|
{
|
||||||
|
AimLines = new AimLinesContainer { Depth = float.MaxValue },
|
||||||
HitMarkers = new HitMarkersContainer(),
|
HitMarkers = new HitMarkersContainer(),
|
||||||
AimMarkers = new AimMarkersContainer { Depth = float.MinValue },
|
AimMarkers = new AimMarkersContainer { Depth = float.MinValue }
|
||||||
AimLines = new AimLinesContainer { Depth = float.MaxValue }
|
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
|
||||||
HitMarkerEnabled.ValueChanged += e => HitMarkers.FadeTo(e.NewValue ? 1 : 0);
|
protected override OsuAnalysisSettings CreateAnalysisSettings()
|
||||||
AimMarkersEnabled.ValueChanged += e => AimMarkers.FadeTo(e.NewValue ? 1 : 0);
|
{
|
||||||
AimLinesEnabled.ValueChanged += e => AimLines.FadeTo(e.NewValue ? 1 : 0);
|
var settings = new OsuAnalysisSettings();
|
||||||
|
settings.HitMarkersEnabled.ValueChanged += e => HitMarkers.FadeTo(e.NewValue ? 1 : 0);
|
||||||
|
settings.AimMarkersEnabled.ValueChanged += e => AimMarkers.FadeTo(e.NewValue ? 1 : 0);
|
||||||
|
settings.AimLinesEnabled.ValueChanged += e => AimLines.FadeTo(e.NewValue ? 1 : 0);
|
||||||
|
settings.CursorHideEnabled.ValueChanged += e => Playfield.Cursor.FadeTo(e.NewValue ? 0 : 1);
|
||||||
|
return settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
@ -51,6 +57,11 @@ namespace osu.Game.Rulesets.Osu.UI
|
|||||||
AimMarkers.Hide();
|
AimMarkers.Hide();
|
||||||
AimLines.Hide();
|
AimLines.Hide();
|
||||||
|
|
||||||
|
LoadReplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void LoadReplay()
|
||||||
|
{
|
||||||
bool leftHeld = false;
|
bool leftHeld = false;
|
||||||
bool rightHeld = false;
|
bool rightHeld = false;
|
||||||
|
|
||||||
|
@ -2,58 +2,23 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Localisation;
|
|
||||||
using osu.Game.Replays;
|
|
||||||
using osu.Game.Rulesets.UI;
|
|
||||||
using osu.Game.Screens.Play.PlayerSettings;
|
using osu.Game.Screens.Play.PlayerSettings;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Osu.UI
|
namespace osu.Game.Rulesets.Osu.UI
|
||||||
{
|
{
|
||||||
public partial class OsuAnalysisSettings : AnalysisSettings
|
public partial class OsuAnalysisSettings : AnalysisSettings
|
||||||
{
|
{
|
||||||
protected new DrawableOsuRuleset DrawableRuleset => (DrawableOsuRuleset)base.DrawableRuleset;
|
[SettingSource("Hit markers", SettingControlType = typeof(PlayerCheckbox))]
|
||||||
|
public BindableBool HitMarkersEnabled { get; } = new BindableBool();
|
||||||
|
|
||||||
private readonly PlayerCheckbox hitMarkerToggle;
|
[SettingSource("Aim markers", SettingControlType = typeof(PlayerCheckbox))]
|
||||||
private readonly PlayerCheckbox aimMarkerToggle;
|
public BindableBool AimMarkersEnabled { get; } = new BindableBool();
|
||||||
private readonly PlayerCheckbox aimLinesToggle;
|
|
||||||
|
|
||||||
public OsuAnalysisSettings(DrawableRuleset drawableRuleset)
|
[SettingSource("Aim lines", SettingControlType = typeof(PlayerCheckbox))]
|
||||||
: base(drawableRuleset)
|
public BindableBool AimLinesEnabled { get; } = new BindableBool();
|
||||||
{
|
|
||||||
PlayerCheckbox hideCursorToggle;
|
|
||||||
|
|
||||||
Children = new Drawable[]
|
[SettingSource("Hide cursor", SettingControlType = typeof(PlayerCheckbox))]
|
||||||
{
|
public BindableBool CursorHideEnabled { get; } = new BindableBool();
|
||||||
hitMarkerToggle = new PlayerCheckbox { LabelText = PlayerSettingsOverlayStrings.HitMarkers },
|
|
||||||
aimMarkerToggle = new PlayerCheckbox { LabelText = PlayerSettingsOverlayStrings.AimMarkers },
|
|
||||||
aimLinesToggle = new PlayerCheckbox { LabelText = PlayerSettingsOverlayStrings.AimLines },
|
|
||||||
hideCursorToggle = new PlayerCheckbox { LabelText = PlayerSettingsOverlayStrings.HideCursor }
|
|
||||||
};
|
|
||||||
|
|
||||||
hideCursorToggle.Current.BindValueChanged(onCursorToggle);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void onCursorToggle(ValueChangedEvent<bool> hide)
|
|
||||||
{
|
|
||||||
// this only hides half the cursor
|
|
||||||
if (hide.NewValue)
|
|
||||||
{
|
|
||||||
DrawableRuleset.Playfield.Cursor.FadeOut();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DrawableRuleset.Playfield.Cursor.FadeIn();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override AnalysisContainer CreateAnalysisContainer(Replay replay)
|
|
||||||
{
|
|
||||||
var analysisContainer = new OsuAnalysisContainer(replay);
|
|
||||||
analysisContainer.HitMarkerEnabled.BindTo(hitMarkerToggle.Current);
|
|
||||||
analysisContainer.AimMarkersEnabled.BindTo(aimMarkerToggle.Current);
|
|
||||||
analysisContainer.AimLinesEnabled.BindTo(aimLinesToggle.Current);
|
|
||||||
return analysisContainer;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,26 +19,6 @@ namespace osu.Game.Localisation
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public static LocalisableString StepForward => new TranslatableString(getKey(@"step_forward_frame"), @"Step forward one frame");
|
public static LocalisableString StepForward => new TranslatableString(getKey(@"step_forward_frame"), @"Step forward one frame");
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// "Hit markers"
|
|
||||||
/// </summary>
|
|
||||||
public static LocalisableString HitMarkers => new TranslatableString(getKey(@"hit_markers"), @"Hit markers");
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// "Aim markers"
|
|
||||||
/// </summary>
|
|
||||||
public static LocalisableString AimMarkers => new TranslatableString(getKey(@"aim_markers"), @"Aim markers");
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// "Hide cursor"
|
|
||||||
/// </summary>
|
|
||||||
public static LocalisableString HideCursor => new TranslatableString(getKey(@"hide_cursor"), @"Hide cursor");
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// "Aim lines"
|
|
||||||
/// </summary>
|
|
||||||
public static LocalisableString AimLines => new TranslatableString(getKey(@"aim_lines"), @"Aim lines");
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// "Seek backward {0} seconds"
|
/// "Seek backward {0} seconds"
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -17,6 +17,7 @@ using osu.Game.Beatmaps.Legacy;
|
|||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Extensions;
|
using osu.Game.Extensions;
|
||||||
using osu.Game.Overlays.Settings;
|
using osu.Game.Overlays.Settings;
|
||||||
|
using osu.Game.Replays;
|
||||||
using osu.Game.Rulesets.Configuration;
|
using osu.Game.Rulesets.Configuration;
|
||||||
using osu.Game.Rulesets.Difficulty;
|
using osu.Game.Rulesets.Difficulty;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
@ -27,7 +28,6 @@ using osu.Game.Rulesets.Scoring;
|
|||||||
using osu.Game.Rulesets.UI;
|
using osu.Game.Rulesets.UI;
|
||||||
using osu.Game.Scoring;
|
using osu.Game.Scoring;
|
||||||
using osu.Game.Screens.Edit.Setup;
|
using osu.Game.Screens.Edit.Setup;
|
||||||
using osu.Game.Screens.Play.PlayerSettings;
|
|
||||||
using osu.Game.Screens.Ranking.Statistics;
|
using osu.Game.Screens.Ranking.Statistics;
|
||||||
using osu.Game.Skinning;
|
using osu.Game.Skinning;
|
||||||
using osu.Game.Users;
|
using osu.Game.Users;
|
||||||
@ -410,6 +410,6 @@ namespace osu.Game.Rulesets
|
|||||||
|
|
||||||
public virtual DifficultySection? CreateEditorDifficultySection() => null;
|
public virtual DifficultySection? CreateEditorDifficultySection() => null;
|
||||||
|
|
||||||
public virtual AnalysisSettings? CreateAnalysisSettings(DrawableRuleset drawableRuleset) => null;
|
public virtual AnalysisContainer? CreateAnalysisContainer(Replay replay, Playfield playfield) => null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,16 +3,25 @@
|
|||||||
|
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Game.Replays;
|
using osu.Game.Replays;
|
||||||
|
using osu.Game.Screens.Play.PlayerSettings;
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.UI
|
namespace osu.Game.Rulesets.UI
|
||||||
{
|
{
|
||||||
public partial class AnalysisContainer : Container
|
public abstract partial class AnalysisContainer : Container
|
||||||
{
|
{
|
||||||
protected Replay Replay;
|
protected Replay Replay;
|
||||||
|
protected Playfield Playfield;
|
||||||
|
|
||||||
public AnalysisContainer(Replay replay)
|
public AnalysisSettings AnalysisSettings;
|
||||||
|
|
||||||
|
public AnalysisContainer(Replay replay, Playfield playfield)
|
||||||
{
|
{
|
||||||
Replay = replay;
|
Replay = replay;
|
||||||
}
|
Playfield = playfield;
|
||||||
|
|
||||||
|
AnalysisSettings = CreateAnalysisSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract AnalysisSettings CreateAnalysisSettings();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,21 +1,16 @@
|
|||||||
// 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.
|
||||||
|
|
||||||
using osu.Game.Replays;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Rulesets.UI;
|
|
||||||
|
|
||||||
namespace osu.Game.Screens.Play.PlayerSettings
|
namespace osu.Game.Screens.Play.PlayerSettings
|
||||||
{
|
{
|
||||||
public abstract partial class AnalysisSettings : PlayerSettingsGroup
|
public partial class AnalysisSettings : PlayerSettingsGroup
|
||||||
{
|
{
|
||||||
protected DrawableRuleset DrawableRuleset;
|
public AnalysisSettings()
|
||||||
|
|
||||||
protected AnalysisSettings(DrawableRuleset drawableRuleset)
|
|
||||||
: base("Analysis Settings")
|
: base("Analysis Settings")
|
||||||
{
|
{
|
||||||
DrawableRuleset = drawableRuleset;
|
AddRange(this.CreateSettingsControls());
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract AnalysisContainer CreateAnalysisContainer(Replay replay);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,12 +72,12 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
HUDOverlay.PlayerSettingsOverlay.AddAtStart(playbackSettings);
|
HUDOverlay.PlayerSettingsOverlay.AddAtStart(playbackSettings);
|
||||||
|
|
||||||
var analysisSettings = DrawableRuleset.Ruleset.CreateAnalysisSettings(DrawableRuleset);
|
var analysisContainer = DrawableRuleset.Ruleset.CreateAnalysisContainer(GameplayState.Score.Replay, DrawableRuleset.Playfield);
|
||||||
|
|
||||||
if (analysisSettings != null)
|
if (analysisContainer != null)
|
||||||
{
|
{
|
||||||
HUDOverlay.PlayerSettingsOverlay.AddAtStart(analysisSettings);
|
HUDOverlay.PlayerSettingsOverlay.AddAtStart(analysisContainer.AnalysisSettings);
|
||||||
DrawableRuleset.Playfield.AddAnalysisContainer(analysisSettings.CreateAnalysisContainer(GameplayState.Score.Replay));
|
DrawableRuleset.Playfield.AddAnalysisContainer(analysisContainer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user