[client] move imgui input state reset to it's own core function

This commit is contained in:
Geoffrey McRae 2021-07-31 20:51:08 +10:00
parent a11a20411b
commit f49948506b
3 changed files with 13 additions and 8 deletions

View File

@ -77,15 +77,9 @@ void app_handleFocusEvent(bool focused)
{
g_state.focused = focused;
if (!focused && g_state.overlayInput)
{
// release any imgui buttons/keys if we lost focus
g_state.io->MouseDown[ImGuiMouseButton_Left ] = false;
g_state.io->MouseDown[ImGuiMouseButton_Right ] = false;
g_state.io->MouseDown[ImGuiMouseButton_Middle] = false;
for(int key = 0; key < sizeof(g_state.io->KeysDown) / sizeof(bool); key++)
g_state.io->KeysDown[key] = false;
}
if (!focused && g_state.overlayInput)
core_resetOverlayInputState();
if (!core_inputEnabled())
{

View File

@ -25,6 +25,7 @@
#include "common/time.h"
#include "common/debug.h"
#include "common/array.h"
#include <assert.h>
#include <math.h>
@ -522,3 +523,12 @@ void core_handleMouseNormal(double ex, double ey)
if (!spice_mouse_motion(x, y))
DEBUG_ERROR("failed to send mouse motion message");
}
void core_resetOverlayInputState(void)
{
g_state.io->MouseDown[ImGuiMouseButton_Left ] = false;
g_state.io->MouseDown[ImGuiMouseButton_Right ] = false;
g_state.io->MouseDown[ImGuiMouseButton_Middle] = false;
for(int key = 0; key < ARRAY_LENGTH(g_state.io->KeysDown); key++)
g_state.io->KeysDown[key] = false;
}

View File

@ -36,5 +36,6 @@ void core_stopFrameThread(void);
void core_handleGuestMouseUpdate(void);
void core_handleMouseGrabbed(double ex, double ey);
void core_handleMouseNormal(double ex, double ey);
void core_resetOverlayInputState(void);
#endif