mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-24 05:37:58 +00:00
[client] add input:captureOnly
to disable input when not captured
This commit is contained in:
parent
5e9cfb9033
commit
f47c8cb806
@ -141,6 +141,7 @@ Command line arguments will override any options loaded from the config files.
|
||||
| input:rawMouse | | no | Use RAW mouse input when in capture mode (good for gaming) |
|
||||
| input:mouseRedraw | | yes | Mouse movements trigger redraws (ignores FPS minimum) |
|
||||
| input:autoCapture | | no | Try to keep the mouse captured when needed |
|
||||
| input:captureOnly | | no | Only enable input via SPICE if in capture mode |
|
||||
|----------------------------------------------------------------------------------------------------------------------------------------------|
|
||||
|
||||
|------------------------------------------------------------------------------------------------------------------|
|
||||
|
@ -310,6 +310,13 @@ static struct Option options[] =
|
||||
.type = OPTION_TYPE_BOOL,
|
||||
.value.x_bool = false
|
||||
},
|
||||
{
|
||||
.module = "input",
|
||||
.name = "captureOnly",
|
||||
.description = "Only enable input via SPICE if in capture mode",
|
||||
.type = OPTION_TYPE_BOOL,
|
||||
.value.x_bool = false
|
||||
},
|
||||
|
||||
// spice options
|
||||
{
|
||||
@ -478,6 +485,7 @@ bool config_load(int argc, char * argv[])
|
||||
params.rawMouse = option_get_bool("input", "rawMouse" );
|
||||
params.mouseRedraw = option_get_bool("input", "mouseRedraw" );
|
||||
params.autoCapture = option_get_bool("input", "autoCapture" );
|
||||
params.captureInputOnly = option_get_bool("input", "captureOnly" );
|
||||
|
||||
params.minimizeOnFocusLoss = option_get_bool("win", "minimizeOnFocusLoss");
|
||||
|
||||
|
@ -100,10 +100,15 @@ static void lgInit()
|
||||
g_cursor.guest.valid = false;
|
||||
}
|
||||
|
||||
static bool inputEnabled()
|
||||
{
|
||||
return params.useSpiceInput && !g_state.ignoreInput &&
|
||||
((g_cursor.grab && params.captureInputOnly) || !params.captureInputOnly);
|
||||
}
|
||||
|
||||
static void alignToGuest()
|
||||
{
|
||||
if (!params.useSpiceInput || g_cursor.grab ||
|
||||
SDL_HasEvent(e_SDLEvent))
|
||||
if (SDL_HasEvent(e_SDLEvent))
|
||||
return;
|
||||
|
||||
SDL_Event event;
|
||||
@ -390,7 +395,8 @@ static int cursorThread(void * unused)
|
||||
g_cursor.guest.y = cursor->y;
|
||||
g_cursor.guest.valid = true;
|
||||
|
||||
if (valid != true)
|
||||
// if the state just became valid
|
||||
if (valid != true && inputEnabled())
|
||||
alignToGuest();
|
||||
}
|
||||
|
||||
@ -1085,6 +1091,8 @@ static void handleResizeEvent(unsigned int w, unsigned int h)
|
||||
g_state.windowCX = w / 2;
|
||||
g_state.windowCY = h / 2;
|
||||
updatePositionInfo();
|
||||
|
||||
if (inputEnabled())
|
||||
alignToGuest();
|
||||
}
|
||||
|
||||
@ -1093,7 +1101,7 @@ static void handleWindowLeave()
|
||||
g_cursor.inWindow = false;
|
||||
g_cursor.inView = false;
|
||||
|
||||
if (!params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
return;
|
||||
|
||||
if (!params.alwaysShowCursor)
|
||||
@ -1105,7 +1113,7 @@ static void handleWindowLeave()
|
||||
static void handleWindowEnter()
|
||||
{
|
||||
g_cursor.inWindow = true;
|
||||
if (!params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
return;
|
||||
|
||||
g_cursor.draw = true;
|
||||
@ -1144,16 +1152,20 @@ static void keyboardUngrab()
|
||||
|
||||
static void setGrab(bool enable)
|
||||
{
|
||||
/* we always do this so that at init the cursor is in the right state */
|
||||
if (params.captureInputOnly && params.hideMouse)
|
||||
SDL_ShowCursor(enable ? SDL_DISABLE : SDL_ENABLE);
|
||||
|
||||
if (g_cursor.grab == enable)
|
||||
return;
|
||||
|
||||
g_cursor.grab = enable;
|
||||
|
||||
if (g_state.wminfo.subsystem != SDL_SYSWM_X11)
|
||||
SDL_SetWindowGrab(g_state.window, g_cursor.grab);
|
||||
SDL_SetWindowGrab(g_state.window, enable);
|
||||
else
|
||||
{
|
||||
if (g_cursor.grab)
|
||||
if (enable)
|
||||
{
|
||||
XGrabPointer(
|
||||
g_state.wminfo.info.x11.display,
|
||||
@ -1187,6 +1199,10 @@ static void setGrab(bool enable)
|
||||
}
|
||||
}
|
||||
|
||||
// if exiting capture when input on capture only, we want to show the cursor
|
||||
if (!enable && (params.captureInputOnly || !params.hideMouse))
|
||||
alignToGuest();
|
||||
|
||||
if (g_cursor.grab)
|
||||
g_cursor.inView = true;
|
||||
|
||||
@ -1294,7 +1310,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
/* support movements via XInput2 */
|
||||
case GenericEvent:
|
||||
{
|
||||
if (!params.useSpiceInput || g_state.ignoreInput)
|
||||
if (!inputEnabled())
|
||||
break;
|
||||
|
||||
XGenericEventCookie *cookie = (XGenericEventCookie*)&xe.xcookie;
|
||||
@ -1417,7 +1433,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
case FocusIn:
|
||||
g_state.focused = true;
|
||||
|
||||
if (!params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
break;
|
||||
|
||||
if (xe.xfocus.mode == NotifyNormal ||
|
||||
@ -1428,7 +1444,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
case FocusOut:
|
||||
g_state.focused = false;
|
||||
|
||||
if (!params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
break;
|
||||
|
||||
if (xe.xfocus.mode == NotifyNormal ||
|
||||
@ -1476,7 +1492,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
break;
|
||||
}
|
||||
|
||||
if (g_state.ignoreInput || !params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
break;
|
||||
|
||||
if (params.ignoreWindowsKeys &&
|
||||
@ -1525,7 +1541,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
g_state.escapeActive = false;
|
||||
}
|
||||
|
||||
if (g_state.ignoreInput || !params.useSpiceInput)
|
||||
if (!inputEnabled())
|
||||
break;
|
||||
|
||||
// avoid sending key up events when we didn't send a down
|
||||
@ -1551,7 +1567,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
}
|
||||
|
||||
case SDL_MOUSEWHEEL:
|
||||
if (g_state.ignoreInput || !params.useSpiceInput || !g_cursor.inView)
|
||||
if (!inputEnabled() || !g_cursor.inView)
|
||||
break;
|
||||
|
||||
if (
|
||||
@ -1566,7 +1582,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
|
||||
case SDL_MOUSEBUTTONDOWN:
|
||||
{
|
||||
if (g_state.ignoreInput || !params.useSpiceInput || !g_cursor.inView)
|
||||
if (!inputEnabled() || !g_cursor.inView)
|
||||
break;
|
||||
|
||||
int button = event->button.button;
|
||||
@ -1583,7 +1599,7 @@ int eventFilter(void * userdata, SDL_Event * event)
|
||||
|
||||
case SDL_MOUSEBUTTONUP:
|
||||
{
|
||||
if (g_state.ignoreInput || !params.useSpiceInput || !g_cursor.inView)
|
||||
if (!inputEnabled() || !g_cursor.inView)
|
||||
break;
|
||||
|
||||
int button = event->button.button;
|
||||
@ -2049,8 +2065,7 @@ static int lg_run()
|
||||
* we start checking for a valid session */
|
||||
SDL_WaitEventTimeout(NULL, 200);
|
||||
|
||||
if (params.captureOnStart)
|
||||
setGrab(true);
|
||||
setGrab(params.captureOnStart);
|
||||
|
||||
uint32_t udataSize;
|
||||
KVMFR *udata;
|
||||
|
@ -141,6 +141,7 @@ struct AppParams
|
||||
bool mouseSmoothing;
|
||||
bool rawMouse;
|
||||
bool autoCapture;
|
||||
bool captureInputOnly;
|
||||
};
|
||||
|
||||
struct CBRequest
|
||||
|
Loading…
Reference in New Issue
Block a user