add IPCKeyInput, since we chose to use dinput for keys, so people can send input to the process somehow. way easier and safer than changing to use win32 keystroke messages
This commit is contained in:
parent
9c21601861
commit
aa8b87129b
|
@ -547,6 +547,7 @@
|
|||
<Compile Include="Input\GamePad360.cs" />
|
||||
<Compile Include="Input\Input.cs" />
|
||||
<Compile Include="IControlMainform.cs" />
|
||||
<Compile Include="Input\IPCKeyInput.cs" />
|
||||
<Compile Include="JumpLists.cs" />
|
||||
<Compile Include="LogConsole.cs" />
|
||||
<Compile Include="LogWindow.cs">
|
||||
|
|
|
@ -0,0 +1,64 @@
|
|||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System;
|
||||
using System.Threading;
|
||||
using System.IO.Pipes;
|
||||
using SlimDX;
|
||||
using SlimDX.DirectInput;
|
||||
|
||||
//this is not a very safe or pretty protocol, I'm not proud of it
|
||||
|
||||
namespace BizHawk.Client.EmuHawk
|
||||
{
|
||||
public static class IPCKeyInput
|
||||
{
|
||||
public static void Initialize()
|
||||
{
|
||||
var t = new Thread(IPCThread);
|
||||
t.IsBackground = true;
|
||||
t.Start();
|
||||
}
|
||||
|
||||
|
||||
static List<KeyInput.KeyEvent> PendingEventList = new List<KeyInput.KeyEvent>();
|
||||
static List<KeyInput.KeyEvent> EventList = new List<KeyInput.KeyEvent>();
|
||||
|
||||
static void IPCThread()
|
||||
{
|
||||
string pipeName = string.Format("bizhawk-pid-{0}-IPCKeyInput", System.Diagnostics.Process.GetCurrentProcess().Id);
|
||||
|
||||
|
||||
for (; ; )
|
||||
{
|
||||
using (NamedPipeServerStream pipe = new NamedPipeServerStream(pipeName, PipeDirection.In, 1, PipeTransmissionMode.Byte, PipeOptions.Asynchronous, 1024, 1024))
|
||||
{
|
||||
try
|
||||
{
|
||||
pipe.WaitForConnection();
|
||||
|
||||
BinaryReader br = new BinaryReader(pipe);
|
||||
|
||||
for (; ; )
|
||||
{
|
||||
int e = br.ReadInt32();
|
||||
bool pressed = (e & 0x80000000) != 0;
|
||||
lock (PendingEventList)
|
||||
PendingEventList.Add(new KeyInput.KeyEvent { Key = (Key)(e & 0x7FFFFFFF), Pressed = pressed });
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static IEnumerable<KeyInput.KeyEvent> Update()
|
||||
{
|
||||
EventList.Clear();
|
||||
|
||||
lock (PendingEventList)
|
||||
EventList.AddRange(PendingEventList);
|
||||
|
||||
return EventList;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -128,6 +128,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
#if WINDOWS
|
||||
KeyInput.Initialize();
|
||||
IPCKeyInput.Initialize();
|
||||
GamePad.Initialize();
|
||||
GamePad360.Initialize();
|
||||
#endif
|
||||
|
@ -319,7 +320,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
for (; ; )
|
||||
{
|
||||
var keyEvents = KeyInput.Update();
|
||||
var keyEvents = KeyInput.Update().Concat(IPCKeyInput.Update());
|
||||
GamePad.UpdateAll();
|
||||
GamePad360.UpdateAll();
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
public static void Initialize()
|
||||
{
|
||||
if (dinput == null)
|
||||
if (dinput == null)
|
||||
dinput = new DirectInput();
|
||||
|
||||
if (keyboard == null || keyboard.Disposed)
|
||||
|
@ -45,7 +45,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
foreach (var k in e.PressedKeys)
|
||||
EventList.Add(new KeyEvent { Key = k, Pressed = true });
|
||||
foreach (var k in e.ReleasedKeys)
|
||||
EventList.Add(new KeyEvent { Key = k, Pressed = false });
|
||||
EventList.Add(new KeyEvent { Key = k, Pressed = false });
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -58,74 +58,5 @@ namespace BizHawk.Client.EmuHawk
|
|||
public bool Pressed;
|
||||
}
|
||||
|
||||
|
||||
public static bool IsPressed(Key key)
|
||||
{
|
||||
if (state.IsPressed(key))
|
||||
return true;
|
||||
|
||||
if (key == Key.LeftShift && state.IsPressed(Key.RightShift))
|
||||
return true;
|
||||
if (key == Key.LeftControl && state.IsPressed(Key.RightControl))
|
||||
return true;
|
||||
if (key == Key.LeftAlt && state.IsPressed(Key.RightAlt))
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
public static bool ShiftModifier
|
||||
{
|
||||
get
|
||||
{
|
||||
if (state.IsPressed(Key.LeftShift)) return true;
|
||||
if (state.IsPressed(Key.RightShift)) return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public static bool CtrlModifier
|
||||
{
|
||||
get
|
||||
{
|
||||
if (state.IsPressed(Key.LeftControl)) return true;
|
||||
if (state.IsPressed(Key.RightControl)) return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public static bool AltModifier
|
||||
{
|
||||
get
|
||||
{
|
||||
if (state.IsPressed(Key.LeftAlt)) return true;
|
||||
if (state.IsPressed(Key.RightAlt)) return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public static Input.ModifierKey GetModifierKeysAsKeys()
|
||||
{
|
||||
Input.ModifierKey ret = Input.ModifierKey.None;
|
||||
if (ShiftModifier) ret |= Input.ModifierKey.Shift;
|
||||
if (CtrlModifier) ret |= Input.ModifierKey.Control;
|
||||
if (AltModifier) ret |= Input.ModifierKey.Alt;
|
||||
return ret;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
internal static class KeyExtensions
|
||||
{
|
||||
public static bool IsModifier(this Key key)
|
||||
{
|
||||
if (key == Key.LeftShift) return true;
|
||||
if (key == Key.RightShift) return true;
|
||||
if (key == Key.LeftControl) return true;
|
||||
if (key == Key.RightControl) return true;
|
||||
if (key == Key.LeftAlt) return true;
|
||||
if (key == Key.RightAlt) return true;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue