mirror of
https://github.com/encounter/SDL.git
synced 2025-10-24 02:35:47 +00:00
Fixed bug 4581 - mouse events with SDL_TOUCH_MOUSEID make window lost focus
Virtual mouse events should never leave the window or change focus for single window applications.
This commit is contained in:
parent
d68e501db4
commit
cfefe5434a
@ -257,15 +257,21 @@ SDL_SendTouch(SDL_TouchID id, SDL_FingerID fingerid,
|
|||||||
if (finger_touching == SDL_FALSE) {
|
if (finger_touching == SDL_FALSE) {
|
||||||
int pos_x = (int)(x * (float)window->w);
|
int pos_x = (int)(x * (float)window->w);
|
||||||
int pos_y = (int)(y * (float)window->h);
|
int pos_y = (int)(y * (float)window->h);
|
||||||
|
if (pos_x >= 0 && pos_y >= 0 && pos_x < window->w && pos_y < window->h) {
|
||||||
SDL_SendMouseMotion(window, SDL_TOUCH_MOUSEID, 0, pos_x, pos_y);
|
SDL_SendMouseMotion(window, SDL_TOUCH_MOUSEID, 0, pos_x, pos_y);
|
||||||
SDL_SendMouseButton(window, SDL_TOUCH_MOUSEID, SDL_PRESSED, SDL_BUTTON_LEFT);
|
SDL_SendMouseButton(window, SDL_TOUCH_MOUSEID, SDL_PRESSED, SDL_BUTTON_LEFT);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (finger_touching == SDL_TRUE && track_touchid == id && track_fingerid == fingerid) {
|
if (finger_touching == SDL_TRUE && track_touchid == id && track_fingerid == fingerid) {
|
||||||
|
int pos_x = (int)(x * (float)window->w);
|
||||||
|
int pos_y = (int)(y * (float)window->h);
|
||||||
|
if (pos_x >= 0 && pos_y >= 0 && pos_x < window->w && pos_y < window->h) {
|
||||||
SDL_SendMouseButton(window, SDL_TOUCH_MOUSEID, SDL_RELEASED, SDL_BUTTON_LEFT);
|
SDL_SendMouseButton(window, SDL_TOUCH_MOUSEID, SDL_RELEASED, SDL_BUTTON_LEFT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (down) {
|
if (down) {
|
||||||
if (finger_touching == SDL_FALSE) {
|
if (finger_touching == SDL_FALSE) {
|
||||||
finger_touching = SDL_TRUE;
|
finger_touching = SDL_TRUE;
|
||||||
@ -355,12 +361,14 @@ SDL_SendTouchMotion(SDL_TouchID id, SDL_FingerID fingerid,
|
|||||||
if (finger_touching == SDL_TRUE && track_touchid == id && track_fingerid == fingerid) {
|
if (finger_touching == SDL_TRUE && track_touchid == id && track_fingerid == fingerid) {
|
||||||
int pos_x = (int)(x * (float)window->w);
|
int pos_x = (int)(x * (float)window->w);
|
||||||
int pos_y = (int)(y * (float)window->h);
|
int pos_y = (int)(y * (float)window->h);
|
||||||
|
if (pos_x >= 0 && pos_y >= 0 && pos_x < window->w && pos_y < window->h) {
|
||||||
SDL_SendMouseMotion(window, SDL_TOUCH_MOUSEID, 0, pos_x, pos_y);
|
SDL_SendMouseMotion(window, SDL_TOUCH_MOUSEID, 0, pos_x, pos_y);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
finger = SDL_GetFinger(touch,fingerid);
|
finger = SDL_GetFinger(touch,fingerid);
|
||||||
if (!finger) {
|
if (!finger) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user