mirror of
https://github.com/Ale32bit/Capy64.git
synced 2025-01-18 10:36:44 +00:00
Remapped interrupt to CTRL + ALT + C. Added reboot keycombo by pressing CTRL + ALT + INS
This commit is contained in:
parent
5f8f946c29
commit
a652992861
2 changed files with 53 additions and 7 deletions
|
@ -3,6 +3,8 @@ using Capy64.Eventing;
|
|||
using Capy64.Eventing.Events;
|
||||
using Capy64.LuaRuntime;
|
||||
using Microsoft.Xna.Framework.Input;
|
||||
using System.Linq;
|
||||
using static Capy64.Eventing.InputManager;
|
||||
|
||||
namespace Capy64.BIOS;
|
||||
|
||||
|
@ -10,6 +12,8 @@ internal class RuntimeInputEvents
|
|||
{
|
||||
private EventEmitter _eventEmitter;
|
||||
private Runtime _runtime;
|
||||
private const int rebootDelay = 30;
|
||||
private int heldReboot = 0;
|
||||
|
||||
public RuntimeInputEvents(EventEmitter eventEmitter, Runtime runtime)
|
||||
{
|
||||
|
@ -27,6 +31,8 @@ internal class RuntimeInputEvents
|
|||
_eventEmitter.OnKeyUp += OnKeyUp;
|
||||
_eventEmitter.OnKeyDown += OnKeyDown;
|
||||
_eventEmitter.OnChar += OnChar;
|
||||
|
||||
_eventEmitter.OnTick += OnTick;
|
||||
}
|
||||
|
||||
public void Unregister()
|
||||
|
@ -39,6 +45,37 @@ internal class RuntimeInputEvents
|
|||
_eventEmitter.OnKeyUp -= OnKeyUp;
|
||||
_eventEmitter.OnKeyDown -= OnKeyDown;
|
||||
_eventEmitter.OnChar -= OnChar;
|
||||
|
||||
_eventEmitter.OnTick -= OnTick;
|
||||
}
|
||||
|
||||
private static Keys[] rebootKeys = new[]
|
||||
{
|
||||
Keys.Insert,
|
||||
Keys.LeftAlt, Keys.RightAlt,
|
||||
Keys.LeftControl, Keys.RightControl,
|
||||
};
|
||||
private void OnTick(object sender, TickEvent e)
|
||||
{
|
||||
var keyState = Keyboard.GetState();
|
||||
var pressedKeys = keyState.GetPressedKeys();
|
||||
|
||||
if ((pressedKeys.Contains(Keys.LeftControl) || pressedKeys.Contains(Keys.RightControl))
|
||||
&& (pressedKeys.Contains(Keys.LeftAlt) || pressedKeys.Contains(Keys.RightAlt))
|
||||
&& pressedKeys.Contains(Keys.Insert))
|
||||
{
|
||||
heldReboot++;
|
||||
}
|
||||
else
|
||||
{
|
||||
heldReboot = 0;
|
||||
}
|
||||
|
||||
if (heldReboot >= rebootDelay)
|
||||
{
|
||||
heldReboot = 0;
|
||||
Bios.Reboot();
|
||||
}
|
||||
}
|
||||
|
||||
private void OnMouseUp(object sender, MouseButtonEvent e)
|
||||
|
@ -99,7 +136,9 @@ internal class RuntimeInputEvents
|
|||
e.IsHeld,
|
||||
});
|
||||
|
||||
if (e.Mods.HasFlag(InputManager.Modifiers.LCtrl) || (e.Mods.HasFlag(InputManager.Modifiers.RCtrl) && !e.IsHeld))
|
||||
if ((e.Mods & Modifiers.Ctrl) != Modifiers.None && !e.IsHeld)
|
||||
{
|
||||
if ((e.Mods & Modifiers.Alt) != Modifiers.None)
|
||||
{
|
||||
if (e.Key == Keys.C)
|
||||
{
|
||||
|
@ -110,6 +149,7 @@ internal class RuntimeInputEvents
|
|||
BypassFilter = true,
|
||||
});
|
||||
}
|
||||
}
|
||||
else if (e.Key == Keys.V)
|
||||
{
|
||||
if (SDL.HasClipboardText())
|
||||
|
|
|
@ -21,6 +21,8 @@ public class InputManager
|
|||
[Flags]
|
||||
public enum Modifiers
|
||||
{
|
||||
None = 0,
|
||||
|
||||
LShift = 1,
|
||||
RShift = 2,
|
||||
|
||||
|
@ -29,6 +31,10 @@ public class InputManager
|
|||
|
||||
LCtrl = 16,
|
||||
RCtrl = 32,
|
||||
|
||||
Shift = LShift | RShift,
|
||||
Alt = LAlt | RAlt,
|
||||
Ctrl = LCtrl | RCtrl,
|
||||
}
|
||||
|
||||
private static Keys[] IgnoredTextInputKeys =
|
||||
|
|
Loading…
Reference in a new issue