Estructura RAWKEYBOARD (winuser.h)
Contiene información sobre el estado del teclado.
Sintaxis
typedef struct tagRAWKEYBOARD {
USHORT MakeCode;
USHORT Flags;
USHORT Reserved;
USHORT VKey;
UINT Message;
ULONG ExtraInformation;
} RAWKEYBOARD, *PRAWKEYBOARD, *LPRAWKEYBOARD;
Miembros
MakeCode
Tipo: de USHORT de
Especifica el código de examen asociado a una tecla presionada. Vea comentarios.
Flags
Tipo: de USHORT de
Marcas para examinar la información del código. Puede ser uno o varios de los siguientes:
Valor | Significado |
---|---|
RI_KEY_MAKE 0 | La tecla está inactiva. |
RI_KEY_BREAK 1 | La tecla está arriba. |
RI_KEY_E0 2 | El código de examen tiene el prefijo E0. |
RI_KEY_E1 4 | El código de examen tiene el prefijo E1. |
Reserved
Tipo: de USHORT de
Reservado; debe ser cero.
VKey
Tipo: de USHORT de
El código de clave virtual heredado correspondiente.
Message
Tipo: UINT
El mensaje de ventana del teclado heredado correspondiente, por ejemplo, WM_KEYDOWN, WM_SYSKEYDOWN, etc.
ExtraInformation
Tipo:
Información adicional específica del dispositivo para el evento.
Observaciones
KEYBOARD_OVERRUN_MAKE_CODE es un valor especial MakeCode enviado cuando se presiona una combinación no válida o no reconocida de teclas o el número de teclas presionadas supera el límite de este teclado.
case WM_INPUT:
{
UINT dwSize = sizeof(RAWINPUT);
static BYTE lpb[sizeof(RAWINPUT)];
GetRawInputData((HRAWINPUT)lParam, RID_INPUT, lpb, &dwSize, sizeof(RAWINPUTHEADER));
RAWINPUT* raw = (RAWINPUT*)lpb;
if (raw->header.dwType == RIM_TYPEKEYBOARD)
{
RAWKEYBOARD& keyboard = raw->data.keyboard;
WORD scanCode = 0;
BOOL keyUp = keyboard.Flags & RI_KEY_BREAK;
// Ignore key overrun state and keys not mapped to any virtual key code
if (keyboard.MakeCode == KEYBOARD_OVERRUN_MAKE_CODE || keyboard.VKey >= UCHAR_MAX)
return 0;
if (keyboard.MakeCode)
{
// Compose the full scan code value with its extended byte
scanCode = MAKEWORD(keyboard.MakeCode & 0x7f, ((keyboard.Flags & RI_KEY_E0) ? 0xe0 : ((keyboard.Flags & RI_KEY_E1) ? 0xe1 : 0x00)));
}
else
{
// Scan code value may be empty for some buttons (for example multimedia buttons)
// Try to get the scan code from the virtual key code
scanCode = LOWORD(MapVirtualKey(keyboard.VKey, MAPVK_VK_TO_VSC_EX));
}
// Get the key name for debug output
TCHAR keyNameBuffer[MAX_PATH] = {};
GetKeyNameText((LONG)MAKELPARAM(0, (HIBYTE(scanCode) ? KF_EXTENDED : 0x00) | LOBYTE(scanCode)), keyNameBuffer, MAX_PATH);
// Debug output
TCHAR printBuffer[MAX_PATH] = {};
StringCchPrintf(printBuffer, MAX_PATH, TEXT("Keyboard: scanCode=%04x keyName=%s\r\n"), scanCode, keyNameBuffer);
OutputDebugString(printBuffer);
}
...
return 0;
}
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Windows XP [solo aplicaciones de escritorio] |
servidor mínimo admitido | Windows Server 2003 [solo aplicaciones de escritorio] |
encabezado de |
winuser.h (incluya Windows.h) |
Consulte también
- GetRawInputDeviceInfo
- RAWINPUT
- de entrada sin procesar
- controladores de cliente HID de teclado y mouse
- KEYBOARD_INPUT_DATA estructura
- entrada de teclado