keeweb/helper/win32/src/KeeWebHelper/WindowsInput/WindowsInputDeviceStateAdap...

157 lines
12 KiB
C#
Executable File

using System;
using WindowsInput.Native;
namespace WindowsInput
{
/// <summary>
/// An implementation of <see cref="IInputDeviceStateAdaptor"/> for Windows by calling the native <see cref="NativeMethods.GetKeyState"/> and <see cref="NativeMethods.GetAsyncKeyState"/> methods.
/// </summary>
public class WindowsInputDeviceStateAdaptor : IInputDeviceStateAdaptor
{
/// <summary>
/// Determines whether the specified key is up or down by calling the GetKeyState function. (See: http://msdn.microsoft.com/en-us/library/ms646301(VS.85).aspx)
/// </summary>
/// <param name="keyCode">The <see cref="VirtualKeyCode"/> for the key.</param>
/// <returns>
/// <c>true</c> if the key is down; otherwise, <c>false</c>.
/// </returns>
/// <remarks>
/// The key status returned from this function changes as a thread reads key messages from its message queue. The status does not reflect the interrupt-level state associated with the hardware. Use the GetAsyncKeyState function to retrieve that information.
/// An application calls GetKeyState in response to a keyboard-input message. This function retrieves the state of the key when the input message was generated.
/// To retrieve state information for all the virtual keys, use the GetKeyboardState function.
/// An application can use the virtual-key code constants VK_SHIFT, VK_CONTROL, and VK_MENU as values for Bthe nVirtKey parameter. This gives the status of the SHIFT, CTRL, or ALT keys without distinguishing between left and right. An application can also use the following virtual-key code constants as values for nVirtKey to distinguish between the left and right instances of those keys.
/// VK_LSHIFT
/// VK_RSHIFT
/// VK_LCONTROL
/// VK_RCONTROL
/// VK_LMENU
/// VK_RMENU
///
/// These left- and right-distinguishing constants are available to an application only through the GetKeyboardState, SetKeyboardState, GetAsyncKeyState, GetKeyState, and MapVirtualKey functions.
/// </remarks>
public bool IsKeyDown(VirtualKeyCode keyCode)
{
Int16 result = NativeMethods.GetKeyState((UInt16)keyCode);
return (result < 0);
}
/// <summary>
/// Determines whether the specified key is up or downby calling the <see cref="NativeMethods.GetKeyState"/> function. (See: http://msdn.microsoft.com/en-us/library/ms646301(VS.85).aspx)
/// </summary>
/// <param name="keyCode">The <see cref="VirtualKeyCode"/> for the key.</param>
/// <returns>
/// <c>true</c> if the key is up; otherwise, <c>false</c>.
/// </returns>
/// <remarks>
/// The key status returned from this function changes as a thread reads key messages from its message queue. The status does not reflect the interrupt-level state associated with the hardware. Use the GetAsyncKeyState function to retrieve that information.
/// An application calls GetKeyState in response to a keyboard-input message. This function retrieves the state of the key when the input message was generated.
/// To retrieve state information for all the virtual keys, use the GetKeyboardState function.
/// An application can use the virtual-key code constants VK_SHIFT, VK_CONTROL, and VK_MENU as values for Bthe nVirtKey parameter. This gives the status of the SHIFT, CTRL, or ALT keys without distinguishing between left and right. An application can also use the following virtual-key code constants as values for nVirtKey to distinguish between the left and right instances of those keys.
/// VK_LSHIFT
/// VK_RSHIFT
/// VK_LCONTROL
/// VK_RCONTROL
/// VK_LMENU
/// VK_RMENU
///
/// These left- and right-distinguishing constants are available to an application only through the GetKeyboardState, SetKeyboardState, GetAsyncKeyState, GetKeyState, and MapVirtualKey functions.
/// </remarks>
public bool IsKeyUp(VirtualKeyCode keyCode)
{
return !IsKeyDown(keyCode);
}
/// <summary>
/// Determines whether the physical key is up or down at the time the function is called regardless of whether the application thread has read the keyboard event from the message pump by calling the <see cref="NativeMethods.GetAsyncKeyState"/> function. (See: http://msdn.microsoft.com/en-us/library/ms646293(VS.85).aspx)
/// </summary>
/// <param name="keyCode">The <see cref="VirtualKeyCode"/> for the key.</param>
/// <returns>
/// <c>true</c> if the key is down; otherwise, <c>false</c>.
/// </returns>
/// <remarks>
/// The GetAsyncKeyState function works with mouse buttons. However, it checks on the state of the physical mouse buttons, not on the logical mouse buttons that the physical buttons are mapped to. For example, the call GetAsyncKeyState(VK_LBUTTON) always returns the state of the left physical mouse button, regardless of whether it is mapped to the left or right logical mouse button. You can determine the system's current mapping of physical mouse buttons to logical mouse buttons by calling
/// Copy CodeGetSystemMetrics(SM_SWAPBUTTON) which returns TRUE if the mouse buttons have been swapped.
///
/// Although the least significant bit of the return value indicates whether the key has been pressed since the last query, due to the pre-emptive multitasking nature of Windows, another application can call GetAsyncKeyState and receive the "recently pressed" bit instead of your application. The behavior of the least significant bit of the return value is retained strictly for compatibility with 16-bit Windows applications (which are non-preemptive) and should not be relied upon.
///
/// You can use the virtual-key code constants VK_SHIFT, VK_CONTROL, and VK_MENU as values for the vKey parameter. This gives the state of the SHIFT, CTRL, or ALT keys without distinguishing between left and right.
///
/// Windows NT/2000/XP: You can use the following virtual-key code constants as values for vKey to distinguish between the left and right instances of those keys.
///
/// Code Meaning
/// VK_LSHIFT Left-shift key.
/// VK_RSHIFT Right-shift key.
/// VK_LCONTROL Left-control key.
/// VK_RCONTROL Right-control key.
/// VK_LMENU Left-menu key.
/// VK_RMENU Right-menu key.
///
/// These left- and right-distinguishing constants are only available when you call the GetKeyboardState, SetKeyboardState, GetAsyncKeyState, GetKeyState, and MapVirtualKey functions.
/// </remarks>
public bool IsHardwareKeyDown(VirtualKeyCode keyCode)
{
var result = NativeMethods.GetAsyncKeyState((UInt16)keyCode);
return (result < 0);
}
/// <summary>
/// Determines whether the physical key is up or down at the time the function is called regardless of whether the application thread has read the keyboard event from the message pump by calling the <see cref="NativeMethods.GetAsyncKeyState"/> function. (See: http://msdn.microsoft.com/en-us/library/ms646293(VS.85).aspx)
/// </summary>
/// <param name="keyCode">The <see cref="VirtualKeyCode"/> for the key.</param>
/// <returns>
/// <c>true</c> if the key is up; otherwise, <c>false</c>.
/// </returns>
/// <remarks>
/// The GetAsyncKeyState function works with mouse buttons. However, it checks on the state of the physical mouse buttons, not on the logical mouse buttons that the physical buttons are mapped to. For example, the call GetAsyncKeyState(VK_LBUTTON) always returns the state of the left physical mouse button, regardless of whether it is mapped to the left or right logical mouse button. You can determine the system's current mapping of physical mouse buttons to logical mouse buttons by calling
/// Copy CodeGetSystemMetrics(SM_SWAPBUTTON) which returns TRUE if the mouse buttons have been swapped.
///
/// Although the least significant bit of the return value indicates whether the key has been pressed since the last query, due to the pre-emptive multitasking nature of Windows, another application can call GetAsyncKeyState and receive the "recently pressed" bit instead of your application. The behavior of the least significant bit of the return value is retained strictly for compatibility with 16-bit Windows applications (which are non-preemptive) and should not be relied upon.
///
/// You can use the virtual-key code constants VK_SHIFT, VK_CONTROL, and VK_MENU as values for the vKey parameter. This gives the state of the SHIFT, CTRL, or ALT keys without distinguishing between left and right.
///
/// Windows NT/2000/XP: You can use the following virtual-key code constants as values for vKey to distinguish between the left and right instances of those keys.
///
/// Code Meaning
/// VK_LSHIFT Left-shift key.
/// VK_RSHIFT Right-shift key.
/// VK_LCONTROL Left-control key.
/// VK_RCONTROL Right-control key.
/// VK_LMENU Left-menu key.
/// VK_RMENU Right-menu key.
///
/// These left- and right-distinguishing constants are only available when you call the GetKeyboardState, SetKeyboardState, GetAsyncKeyState, GetKeyState, and MapVirtualKey functions.
/// </remarks>
public bool IsHardwareKeyUp(VirtualKeyCode keyCode)
{
return !IsHardwareKeyDown(keyCode);
}
/// <summary>
/// Determines whether the toggling key is toggled on (in-effect) or not by calling the <see cref="NativeMethods.GetKeyState"/> function. (See: http://msdn.microsoft.com/en-us/library/ms646301(VS.85).aspx)
/// </summary>
/// <param name="keyCode">The <see cref="VirtualKeyCode"/> for the key.</param>
/// <returns>
/// <c>true</c> if the toggling key is toggled on (in-effect); otherwise, <c>false</c>.
/// </returns>
/// <remarks>
/// The key status returned from this function changes as a thread reads key messages from its message queue. The status does not reflect the interrupt-level state associated with the hardware. Use the GetAsyncKeyState function to retrieve that information.
/// An application calls GetKeyState in response to a keyboard-input message. This function retrieves the state of the key when the input message was generated.
/// To retrieve state information for all the virtual keys, use the GetKeyboardState function.
/// An application can use the virtual-key code constants VK_SHIFT, VK_CONTROL, and VK_MENU as values for the nVirtKey parameter. This gives the status of the SHIFT, CTRL, or ALT keys without distinguishing between left and right. An application can also use the following virtual-key code constants as values for nVirtKey to distinguish between the left and right instances of those keys.
/// VK_LSHIFT
/// VK_RSHIFT
/// VK_LCONTROL
/// VK_RCONTROL
/// VK_LMENU
/// VK_RMENU
///
/// These left- and right-distinguishing constants are available to an application only through the GetKeyboardState, SetKeyboardState, GetAsyncKeyState, GetKeyState, and MapVirtualKey functions.
/// </remarks>
public bool IsTogglingKeyInEffect(VirtualKeyCode keyCode)
{
Int16 result = NativeMethods.GetKeyState((UInt16)keyCode);
return (result & 0x01) == 0x01;
}
}
}