mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-07 18:39:37 +01:00
Allow mouse messages from Wacom pens, e.g. right click pen buttons, etc.
This commit is contained in:
parent
afb9ff9507
commit
cc64b369fb
@ -47,9 +47,6 @@
|
|||||||
#include "wmmsg.h"
|
#include "wmmsg.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* For processing mouse WM_*BUTTON* and WM_MOUSEMOVE message-data from GetMessageExtraInfo() */
|
|
||||||
#define MOUSEEVENTF_FROMTOUCH 0xFF515700
|
|
||||||
|
|
||||||
/* Masks for processing the windows KEYDOWN and KEYUP messages */
|
/* Masks for processing the windows KEYDOWN and KEYUP messages */
|
||||||
#define REPEATED_KEYMASK (1<<30)
|
#define REPEATED_KEYMASK (1<<30)
|
||||||
#define EXTENDED_KEYMASK (1<<24)
|
#define EXTENDED_KEYMASK (1<<24)
|
||||||
@ -246,7 +243,7 @@ WIN_CheckWParamMouseButton(SDL_bool bwParamMousePressed, SDL_bool bSDLMousePress
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Some windows systems fail to send a WM_LBUTTONDOWN sometimes, but each mouse move contains the current button state also
|
* Some windows systems fail to send a WM_LBUTTONDOWN sometimes, but each mouse move contains the current button state also
|
||||||
* so this funciton reconciles our view of the world with the current buttons reported by windows
|
* so this function reconciles our view of the world with the current buttons reported by windows
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
WIN_CheckWParamMouseButtons(WPARAM wParam, SDL_WindowData *data, SDL_MouseID mouseID)
|
WIN_CheckWParamMouseButtons(WPARAM wParam, SDL_WindowData *data, SDL_MouseID mouseID)
|
||||||
@ -365,26 +362,40 @@ static SDL_bool isVistaOrNewer = SDL_FALSE;
|
|||||||
This is used to implement a workaround.. */
|
This is used to implement a workaround.. */
|
||||||
static SDL_bool isWin10FCUorNewer = SDL_FALSE;
|
static SDL_bool isWin10FCUorNewer = SDL_FALSE;
|
||||||
|
|
||||||
/* Checks a mouse or raw packet for touch indication.
|
/* We want to generate mouse events from mouse and pen, and touch events from touchscreens */
|
||||||
returns: 0 for not touch input, 1 for touch input.
|
#define MI_WP_SIGNATURE 0xFF515700
|
||||||
*/
|
#define MI_WP_SIGNATURE_MASK 0xFFFFFF00
|
||||||
static LPARAM
|
#define IsTouchEvent(dw) ((dw) & MI_WP_SIGNATURE_MASK) == MI_WP_SIGNATURE
|
||||||
GetMessageExtraInfoAndCheckMousePacketTouch(int *checkTouch) {
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_MOUSE_EVENT_SOURCE_UNKNOWN,
|
||||||
|
SDL_MOUSE_EVENT_SOURCE_MOUSE,
|
||||||
|
SDL_MOUSE_EVENT_SOURCE_TOUCH,
|
||||||
|
SDL_MOUSE_EVENT_SOURCE_PEN,
|
||||||
|
} SDL_MOUSE_EVENT_SOURCE;
|
||||||
|
|
||||||
|
static SDL_MOUSE_EVENT_SOURCE GetMouseMessageSource()
|
||||||
|
{
|
||||||
LPARAM extrainfo = GetMessageExtraInfo();
|
LPARAM extrainfo = GetMessageExtraInfo();
|
||||||
/* Mouse data (ignoring synthetic mouse events generated for touchscreens) */
|
/* Mouse data (ignoring synthetic mouse events generated for touchscreens) */
|
||||||
/* Versions below Vista will set the low 7 bits to the Mouse ID and don't use bit 7:
|
/* Versions below Vista will set the low 7 bits to the Mouse ID and don't use bit 7:
|
||||||
Check bits 8-32 for the signature (which will indicate a Tablet PC Pen or Touch Device).
|
Check bits 8-32 for the signature (which will indicate a Tablet PC Pen or Touch Device).
|
||||||
Only check bit 7 when Vista and up(Cleared=Pen, Set=Touch(which we need to filter out)),
|
Only check bit 7 when Vista and up(Cleared=Pen, Set=Touch(which we need to filter out)),
|
||||||
when the signature is set. The Mouse ID will be zero for an actual mouse. */
|
when the signature is set. The Mouse ID will be zero for an actual mouse. */
|
||||||
*checkTouch = (!(((extrainfo & 0x7F) && (isVistaOrNewer ? (extrainfo & 0x80) : 1)) || ((extrainfo & 0xFFFFFF00) == 0xFF515700)));
|
if (IsTouchEvent(extrainfo)) {
|
||||||
return extrainfo;
|
if (extrainfo & 0x80) {
|
||||||
|
return SDL_MOUSE_EVENT_SOURCE_TOUCH;
|
||||||
|
} else {
|
||||||
|
return SDL_MOUSE_EVENT_SOURCE_PEN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SDL_MOUSE_EVENT_SOURCE_MOUSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
LRESULT CALLBACK
|
LRESULT CALLBACK
|
||||||
WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
{
|
{
|
||||||
int checkTouch = -1; /* Default to -1 for not yet loaded */
|
|
||||||
LPARAM extrainfo; /* The extra info when checkTouch >= 0. */
|
|
||||||
SDL_WindowData *data;
|
SDL_WindowData *data;
|
||||||
LRESULT returnCode = -1;
|
LRESULT returnCode = -1;
|
||||||
|
|
||||||
@ -512,10 +523,9 @@ WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|||||||
case WM_MOUSEMOVE:
|
case WM_MOUSEMOVE:
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
extrainfo = GetMessageExtraInfoAndCheckMousePacketTouch(&checkTouch); /* load */
|
|
||||||
if (!mouse->relative_mode || mouse->relative_mode_warp) {
|
if (!mouse->relative_mode || mouse->relative_mode_warp) {
|
||||||
/* Only generate mouse events for real mouse */
|
/* Only generate mouse events for real mouse */
|
||||||
if (((extrainfo & MOUSEEVENTF_FROMTOUCH) != MOUSEEVENTF_FROMTOUCH) && checkTouch) {
|
if (GetMouseMessageSource() != SDL_MOUSE_EVENT_SOURCE_TOUCH) {
|
||||||
SDL_SendMouseMotion(data->window, 0, 0, GET_X_LPARAM(lParam), GET_Y_LPARAM(lParam));
|
SDL_SendMouseMotion(data->window, 0, 0, GET_X_LPARAM(lParam), GET_Y_LPARAM(lParam));
|
||||||
if (isWin10FCUorNewer && mouse->relative_mode_warp) {
|
if (isWin10FCUorNewer && mouse->relative_mode_warp) {
|
||||||
/* To work around #3931, Win10 bug introduced in Fall Creators Update, where
|
/* To work around #3931, Win10 bug introduced in Fall Creators Update, where
|
||||||
@ -546,11 +556,8 @@ WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|||||||
case WM_XBUTTONDBLCLK:
|
case WM_XBUTTONDBLCLK:
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
if (checkTouch < 0) {
|
|
||||||
extrainfo = GetMessageExtraInfoAndCheckMousePacketTouch(&checkTouch);
|
|
||||||
}
|
|
||||||
if (!mouse->relative_mode || mouse->relative_mode_warp) {
|
if (!mouse->relative_mode || mouse->relative_mode_warp) {
|
||||||
if (((extrainfo & MOUSEEVENTF_FROMTOUCH) != MOUSEEVENTF_FROMTOUCH) && checkTouch) {
|
if (GetMouseMessageSource() != SDL_MOUSE_EVENT_SOURCE_TOUCH) {
|
||||||
WIN_CheckWParamMouseButtons(wParam, data, 0);
|
WIN_CheckWParamMouseButtons(wParam, data, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -576,9 +583,9 @@ WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|||||||
|
|
||||||
/* Mouse data (ignoring synthetic mouse events generated for touchscreens) */
|
/* Mouse data (ignoring synthetic mouse events generated for touchscreens) */
|
||||||
if (inp.header.dwType == RIM_TYPEMOUSE) {
|
if (inp.header.dwType == RIM_TYPEMOUSE) {
|
||||||
extrainfo = GetMessageExtraInfoAndCheckMousePacketTouch(&checkTouch);
|
if (GetMouseMessageSource() == SDL_MOUSE_EVENT_SOURCE_TOUCH) {
|
||||||
if (!checkTouch)
|
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
if (isRelative) {
|
if (isRelative) {
|
||||||
RAWMOUSE* rawmouse = &inp.data.mouse;
|
RAWMOUSE* rawmouse = &inp.data.mouse;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user