mirror of https://github.com/encounter/SDL.git
cocoa: Another attempt at synthesized mouse/touch events.
This commit is contained in:
parent
294574647d
commit
d9a2eff26f
|
@ -103,11 +103,7 @@ SDL_TouchMouseEventsChanged(void *userdata, const char *name, const char *oldVal
|
||||||
if (hint && (*hint == '0' || SDL_strcasecmp(hint, "false") == 0)) {
|
if (hint && (*hint == '0' || SDL_strcasecmp(hint, "false") == 0)) {
|
||||||
mouse->touch_mouse_events = SDL_FALSE;
|
mouse->touch_mouse_events = SDL_FALSE;
|
||||||
} else {
|
} else {
|
||||||
#if defined(__MACOSX__) /* macOS synthesizes its own events for this. */
|
|
||||||
mouse->touch_mouse_events = SDL_FALSE;
|
|
||||||
#else
|
|
||||||
mouse->touch_mouse_events = SDL_TRUE;
|
mouse->touch_mouse_events = SDL_TRUE;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -387,11 +383,13 @@ SDL_PrivateSendMouseMotion(SDL_Window * window, SDL_MouseID mouseID, int relativ
|
||||||
mouse->has_position = SDL_TRUE;
|
mouse->has_position = SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef __MACOSX__ /* all your trackpad input would lack relative motion when not dragging in this case. */
|
||||||
/* Ignore relative motion positioning the first touch */
|
/* Ignore relative motion positioning the first touch */
|
||||||
if (mouseID == SDL_TOUCH_MOUSEID && !mouse->buttonstate) {
|
if (mouseID == SDL_TOUCH_MOUSEID && !mouse->buttonstate) {
|
||||||
xrel = 0;
|
xrel = 0;
|
||||||
yrel = 0;
|
yrel = 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Update internal mouse coordinates */
|
/* Update internal mouse coordinates */
|
||||||
if (!mouse->relative_mode) {
|
if (!mouse->relative_mode) {
|
||||||
|
|
|
@ -32,9 +32,18 @@ static int SDL_num_touch = 0;
|
||||||
static SDL_Touch **SDL_touchDevices = NULL;
|
static SDL_Touch **SDL_touchDevices = NULL;
|
||||||
|
|
||||||
/* for mapping touch events to mice */
|
/* for mapping touch events to mice */
|
||||||
|
|
||||||
|
#ifndef __MACOSX__ /* don't generate mouse events from touch on macOS, the OS handles that. */
|
||||||
|
#define SYNTHESIZE_TOUCH_TO_MOUSE 1
|
||||||
|
#else
|
||||||
|
#define SYNTHESIZE_TOUCH_TO_MOUSE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if SYNTHESIZE_TOUCH_TO_MOUSE
|
||||||
static SDL_bool finger_touching = SDL_FALSE;
|
static SDL_bool finger_touching = SDL_FALSE;
|
||||||
static SDL_FingerID track_fingerid;
|
static SDL_FingerID track_fingerid;
|
||||||
static SDL_TouchID track_touchid;
|
static SDL_TouchID track_touchid;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Public functions */
|
/* Public functions */
|
||||||
int
|
int
|
||||||
|
@ -245,6 +254,7 @@ SDL_SendTouch(SDL_TouchID id, SDL_FingerID fingerid,
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if SYNTHESIZE_TOUCH_TO_MOUSE
|
||||||
/* SDL_HINT_TOUCH_MOUSE_EVENTS: controlling whether touch events should generate synthetic mouse events */
|
/* SDL_HINT_TOUCH_MOUSE_EVENTS: controlling whether touch events should generate synthetic mouse events */
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
@ -284,6 +294,7 @@ SDL_SendTouch(SDL_TouchID id, SDL_FingerID fingerid,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
finger = SDL_GetFinger(touch, fingerid);
|
finger = SDL_GetFinger(touch, fingerid);
|
||||||
if (down) {
|
if (down) {
|
||||||
|
@ -349,6 +360,7 @@ SDL_SendTouchMotion(SDL_TouchID id, SDL_FingerID fingerid,
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if SYNTHESIZE_TOUCH_TO_MOUSE
|
||||||
/* SDL_HINT_TOUCH_MOUSE_EVENTS: controlling whether touch events should generate synthetic mouse events */
|
/* SDL_HINT_TOUCH_MOUSE_EVENTS: controlling whether touch events should generate synthetic mouse events */
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
@ -369,6 +381,7 @@ SDL_SendTouchMotion(SDL_TouchID id, SDL_FingerID fingerid,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
finger = SDL_GetFinger(touch,fingerid);
|
finger = SDL_GetFinger(touch,fingerid);
|
||||||
if (!finger) {
|
if (!finger) {
|
||||||
|
|
|
@ -375,6 +375,15 @@ Cocoa_HandleMouseEvent(_THIS, NSEvent *event)
|
||||||
return; /* can happen when returning from fullscreen Space on shutdown */
|
return; /* can happen when returning from fullscreen Space on shutdown */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
||||||
|
if ([event subtype] == NSEventSubtypeTouch) { /* this is a synthetic from the OS */
|
||||||
|
if (mouse->touch_mouse_events) {
|
||||||
|
mouseID = SDL_TOUCH_MOUSEID; /* Hint is set */
|
||||||
|
} else {
|
||||||
|
return; /* no hint set, drop this one. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const SDL_bool seenWarp = driverdata->seenWarp;
|
const SDL_bool seenWarp = driverdata->seenWarp;
|
||||||
driverdata->seenWarp = NO;
|
driverdata->seenWarp = NO;
|
||||||
|
|
||||||
|
@ -408,13 +417,21 @@ Cocoa_HandleMouseEvent(_THIS, NSEvent *event)
|
||||||
DLog("Motion was (%g, %g), offset to (%g, %g)", [event deltaX], [event deltaY], deltaX, deltaY);
|
DLog("Motion was (%g, %g), offset to (%g, %g)", [event deltaX], [event deltaY], deltaX, deltaY);
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_SendMouseMotion(mouse->focus, mouse->mouseID, 1, (int)deltaX, (int)deltaY);
|
SDL_SendMouseMotion(mouse->focus, mouseID, 1, (int)deltaX, (int)deltaY);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
Cocoa_HandleMouseWheel(SDL_Window *window, NSEvent *event)
|
Cocoa_HandleMouseWheel(SDL_Window *window, NSEvent *event)
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
||||||
|
if ([event subtype] == NSEventSubtypeTouch) { /* this is a synthetic from the OS */
|
||||||
|
if (mouse->touch_mouse_events) {
|
||||||
|
mouseID = SDL_TOUCH_MOUSEID; /* Hint is set */
|
||||||
|
} else {
|
||||||
|
return; /* no hint set, drop this one. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CGFloat x = -[event deltaX];
|
CGFloat x = -[event deltaX];
|
||||||
CGFloat y = [event deltaY];
|
CGFloat y = [event deltaY];
|
||||||
|
@ -437,7 +454,7 @@ Cocoa_HandleMouseWheel(SDL_Window *window, NSEvent *event)
|
||||||
y = SDL_floor(y);
|
y = SDL_floor(y);
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_SendMouseWheel(window, mouse->mouseID, x, y, direction);
|
SDL_SendMouseWheel(window, mouseID, x, y, direction);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -893,9 +893,19 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
|
|
||||||
- (void)mouseDown:(NSEvent *)theEvent
|
- (void)mouseDown:(NSEvent *)theEvent
|
||||||
{
|
{
|
||||||
|
const SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
||||||
int button;
|
int button;
|
||||||
int clicks;
|
int clicks;
|
||||||
|
|
||||||
|
if ([theEvent subtype] == NSEventSubtypeTouch) { /* this is a synthetic from the OS */
|
||||||
|
if (mouse->touch_mouse_events) {
|
||||||
|
mouseID = SDL_TOUCH_MOUSEID; /* Hint is set */
|
||||||
|
} else {
|
||||||
|
return; /* no hint set, drop this one. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Ignore events that aren't inside the client area (i.e. title bar.) */
|
/* Ignore events that aren't inside the client area (i.e. title bar.) */
|
||||||
if ([theEvent window]) {
|
if ([theEvent window]) {
|
||||||
NSRect windowRect = [[[theEvent window] contentView] frame];
|
NSRect windowRect = [[[theEvent window] contentView] frame];
|
||||||
|
@ -933,8 +943,6 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
|
|
||||||
clicks = (int) [theEvent clickCount];
|
clicks = (int) [theEvent clickCount];
|
||||||
|
|
||||||
const SDL_Mouse *mouse = SDL_GetMouse();
|
|
||||||
const SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
|
||||||
SDL_SendMouseButtonClicks(_data->window, mouseID, SDL_PRESSED, button, clicks);
|
SDL_SendMouseButtonClicks(_data->window, mouseID, SDL_PRESSED, button, clicks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -950,9 +958,19 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
|
|
||||||
- (void)mouseUp:(NSEvent *)theEvent
|
- (void)mouseUp:(NSEvent *)theEvent
|
||||||
{
|
{
|
||||||
|
const SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
||||||
int button;
|
int button;
|
||||||
int clicks;
|
int clicks;
|
||||||
|
|
||||||
|
if ([theEvent subtype] == NSEventSubtypeTouch) { /* this is a synthetic from the OS */
|
||||||
|
if (mouse->touch_mouse_events) {
|
||||||
|
mouseID = SDL_TOUCH_MOUSEID; /* Hint is set */
|
||||||
|
} else {
|
||||||
|
return; /* no hint set, drop this one. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ([self processHitTest:theEvent]) {
|
if ([self processHitTest:theEvent]) {
|
||||||
SDL_SendWindowEvent(_data->window, SDL_WINDOWEVENT_HIT_TEST, 0, 0);
|
SDL_SendWindowEvent(_data->window, SDL_WINDOWEVENT_HIT_TEST, 0, 0);
|
||||||
return; /* stopped dragging, drop event. */
|
return; /* stopped dragging, drop event. */
|
||||||
|
@ -980,8 +998,6 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
|
|
||||||
clicks = (int) [theEvent clickCount];
|
clicks = (int) [theEvent clickCount];
|
||||||
|
|
||||||
const SDL_Mouse *mouse = SDL_GetMouse();
|
|
||||||
const SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
|
||||||
SDL_SendMouseButtonClicks(_data->window, mouseID, SDL_RELEASED, button, clicks);
|
SDL_SendMouseButtonClicks(_data->window, mouseID, SDL_RELEASED, button, clicks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -998,10 +1014,19 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
- (void)mouseMoved:(NSEvent *)theEvent
|
- (void)mouseMoved:(NSEvent *)theEvent
|
||||||
{
|
{
|
||||||
SDL_Mouse *mouse = SDL_GetMouse();
|
SDL_Mouse *mouse = SDL_GetMouse();
|
||||||
|
SDL_MouseID mouseID = mouse ? mouse->mouseID : 0;
|
||||||
SDL_Window *window = _data->window;
|
SDL_Window *window = _data->window;
|
||||||
NSPoint point;
|
NSPoint point;
|
||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
|
if ([theEvent subtype] == NSEventSubtypeTouch) { /* this is a synthetic from the OS */
|
||||||
|
if (mouse->touch_mouse_events) {
|
||||||
|
mouseID = SDL_TOUCH_MOUSEID; /* Hint is set */
|
||||||
|
} else {
|
||||||
|
return; /* no hint set, drop this one. */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ([self processHitTest:theEvent]) {
|
if ([self processHitTest:theEvent]) {
|
||||||
SDL_SendWindowEvent(window, SDL_WINDOWEVENT_HIT_TEST, 0, 0);
|
SDL_SendWindowEvent(window, SDL_WINDOWEVENT_HIT_TEST, 0, 0);
|
||||||
return; /* dragging, drop event. */
|
return; /* dragging, drop event. */
|
||||||
|
@ -1046,7 +1071,7 @@ SetWindowStyle(SDL_Window * window, NSUInteger style)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_SendMouseMotion(window, mouse->mouseID, 0, x, y);
|
SDL_SendMouseMotion(window, mouseID, 0, x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)mouseDragged:(NSEvent *)theEvent
|
- (void)mouseDragged:(NSEvent *)theEvent
|
||||||
|
|
Loading…
Reference in New Issue