Added support for pause/play/speed hotkeys in replays
This commit is contained in:
@@ -269,6 +269,11 @@ namespace OpenRA
|
|||||||
public Hotkey SupportPower05Key = new Hotkey(Keycode.UNKNOWN, Modifiers.None);
|
public Hotkey SupportPower05Key = new Hotkey(Keycode.UNKNOWN, Modifiers.None);
|
||||||
public Hotkey SupportPower06Key = new Hotkey(Keycode.UNKNOWN, Modifiers.None);
|
public Hotkey SupportPower06Key = new Hotkey(Keycode.UNKNOWN, Modifiers.None);
|
||||||
|
|
||||||
|
public Hotkey ReplaySpeedSlowKey = new Hotkey(Keycode.F5, Modifiers.None);
|
||||||
|
public Hotkey ReplaySpeedRegularKey = new Hotkey(Keycode.F6, Modifiers.None);
|
||||||
|
public Hotkey ReplaySpeedFastKey = new Hotkey(Keycode.F7, Modifiers.None);
|
||||||
|
public Hotkey ReplaySpeedMaxKey = new Hotkey(Keycode.F8, Modifiers.None);
|
||||||
|
|
||||||
static readonly Func<KeySettings, Hotkey>[] ProductionKeys = GetKeys(24, "Production");
|
static readonly Func<KeySettings, Hotkey>[] ProductionKeys = GetKeys(24, "Production");
|
||||||
static readonly Func<KeySettings, Hotkey>[] SupportPowerKeys = GetKeys(6, "SupportPower");
|
static readonly Func<KeySettings, Hotkey>[] SupportPowerKeys = GetKeys(6, "SupportPower");
|
||||||
|
|
||||||
|
|||||||
@@ -46,15 +46,18 @@ namespace OpenRA.Mods.Common.Widgets.Logic
|
|||||||
var originalTimestep = world.Timestep;
|
var originalTimestep = world.Timestep;
|
||||||
|
|
||||||
var pauseButton = widget.Get<ButtonWidget>("BUTTON_PAUSE");
|
var pauseButton = widget.Get<ButtonWidget>("BUTTON_PAUSE");
|
||||||
|
pauseButton.GetKey = _ => Game.Settings.Keys.PauseKey;
|
||||||
pauseButton.IsVisible = () => world.Timestep != 0 && orderManager.NetFrameNumber < replayNetTicks;
|
pauseButton.IsVisible = () => world.Timestep != 0 && orderManager.NetFrameNumber < replayNetTicks;
|
||||||
pauseButton.OnClick = () => world.Timestep = 0;
|
pauseButton.OnClick = () => world.Timestep = 0;
|
||||||
|
|
||||||
var playButton = widget.Get<ButtonWidget>("BUTTON_PLAY");
|
var playButton = widget.Get<ButtonWidget>("BUTTON_PLAY");
|
||||||
|
playButton.GetKey = _ => Game.Settings.Keys.PauseKey;
|
||||||
playButton.IsVisible = () => world.Timestep == 0 || orderManager.NetFrameNumber >= replayNetTicks;
|
playButton.IsVisible = () => world.Timestep == 0 || orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
playButton.OnClick = () => world.Timestep = (int)Math.Ceiling(originalTimestep * multipliers[speed]);
|
playButton.OnClick = () => world.Timestep = (int)Math.Ceiling(originalTimestep * multipliers[speed]);
|
||||||
playButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
playButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
|
|
||||||
var slowButton = widget.Get<ButtonWidget>("BUTTON_SLOW");
|
var slowButton = widget.Get<ButtonWidget>("BUTTON_SLOW");
|
||||||
|
slowButton.GetKey = _ => Game.Settings.Keys.ReplaySpeedSlowKey;
|
||||||
slowButton.IsHighlighted = () => speed == PlaybackSpeed.Slow;
|
slowButton.IsHighlighted = () => speed == PlaybackSpeed.Slow;
|
||||||
slowButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
slowButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
slowButton.OnClick = () =>
|
slowButton.OnClick = () =>
|
||||||
@@ -65,6 +68,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
|
|||||||
};
|
};
|
||||||
|
|
||||||
var normalSpeedButton = widget.Get<ButtonWidget>("BUTTON_REGULAR");
|
var normalSpeedButton = widget.Get<ButtonWidget>("BUTTON_REGULAR");
|
||||||
|
normalSpeedButton.GetKey = _ => Game.Settings.Keys.ReplaySpeedRegularKey;
|
||||||
normalSpeedButton.IsHighlighted = () => speed == PlaybackSpeed.Regular;
|
normalSpeedButton.IsHighlighted = () => speed == PlaybackSpeed.Regular;
|
||||||
normalSpeedButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
normalSpeedButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
normalSpeedButton.OnClick = () =>
|
normalSpeedButton.OnClick = () =>
|
||||||
@@ -75,6 +79,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
|
|||||||
};
|
};
|
||||||
|
|
||||||
var fastButton = widget.Get<ButtonWidget>("BUTTON_FAST");
|
var fastButton = widget.Get<ButtonWidget>("BUTTON_FAST");
|
||||||
|
fastButton.GetKey = _ => Game.Settings.Keys.ReplaySpeedFastKey;
|
||||||
fastButton.IsHighlighted = () => speed == PlaybackSpeed.Fast;
|
fastButton.IsHighlighted = () => speed == PlaybackSpeed.Fast;
|
||||||
fastButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
fastButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
fastButton.OnClick = () =>
|
fastButton.OnClick = () =>
|
||||||
@@ -85,6 +90,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
|
|||||||
};
|
};
|
||||||
|
|
||||||
var maximumButton = widget.Get<ButtonWidget>("BUTTON_MAXIMUM");
|
var maximumButton = widget.Get<ButtonWidget>("BUTTON_MAXIMUM");
|
||||||
|
maximumButton.GetKey = _ => Game.Settings.Keys.ReplaySpeedMaxKey;
|
||||||
maximumButton.IsHighlighted = () => speed == PlaybackSpeed.Maximum;
|
maximumButton.IsHighlighted = () => speed == PlaybackSpeed.Maximum;
|
||||||
maximumButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
maximumButton.IsDisabled = () => orderManager.NetFrameNumber >= replayNetTicks;
|
||||||
maximumButton.OnClick = () =>
|
maximumButton.OnClick = () =>
|
||||||
|
|||||||
@@ -467,7 +467,12 @@ namespace OpenRA.Mods.Common.Widgets.Logic
|
|||||||
var hotkeys = new Dictionary<string, string>()
|
var hotkeys = new Dictionary<string, string>()
|
||||||
{
|
{
|
||||||
{ "ObserverCombinedView", "All Players" },
|
{ "ObserverCombinedView", "All Players" },
|
||||||
{ "ObserverWorldView", "Disable Shroud" }
|
{ "ObserverWorldView", "Disable Shroud" },
|
||||||
|
{ "PauseKey", "Pause/Play" },
|
||||||
|
{ "ReplaySpeedSlowKey", "Slow speed" },
|
||||||
|
{ "ReplaySpeedRegularKey", "Regular speed" },
|
||||||
|
{ "ReplaySpeedFastKey", "Fast speed" },
|
||||||
|
{ "ReplaySpeedMaxKey", "Maximum speed" }
|
||||||
};
|
};
|
||||||
|
|
||||||
var header = ScrollItemWidget.Setup(hotkeyHeader, returnTrue, doNothing);
|
var header = ScrollItemWidget.Setup(hotkeyHeader, returnTrue, doNothing);
|
||||||
|
|||||||
Reference in New Issue
Block a user