Quartz: Handle mouse centering hotkey.

Co-authored-by: Dentomologist <dentomologist@gmail.com>
This commit is contained in:
Admiral H. Curtiss 2022-07-21 00:15:00 +02:00
parent e0870166ef
commit d14bd10cd7
No known key found for this signature in database
GPG Key ID: F051B4C4044F33FB
1 changed files with 30 additions and 8 deletions

View File

@ -8,6 +8,8 @@
#include <Carbon/Carbon.h>
#include <Cocoa/Cocoa.h>
#include "Core/Host.h"
#include "InputCommon/ControllerInterface/ControllerInterface.h"
namespace ciface::Quartz
@ -192,16 +194,36 @@ void KeyboardAndMouse::UpdateInput()
CFRelease(windowDescriptions);
CFRelease(windowArray);
CGEventRef event = CGEventCreate(nil);
CGPoint loc = CGEventGetLocation(event);
CFRelease(event);
const double window_width = std::max(bounds.size.width, 1.0);
const double window_height = std::max(bounds.size.height, 1.0);
const auto window_scale = g_controller_interface.GetWindowInputScale();
if (g_controller_interface.IsMouseCenteringRequested() && Host_RendererHasFocus())
{
m_cursor.x = 0;
m_cursor.y = 0;
loc.x -= bounds.origin.x;
loc.y -= bounds.origin.y;
m_cursor.x = (loc.x / std::max(bounds.size.width, 1.0) * 2 - 1.0) * window_scale.x;
m_cursor.y = (loc.y / std::max(bounds.size.height, 1.0) * 2 - 1.0) * window_scale.y;
const CGPoint window_center_global_coordinates =
CGPointMake(bounds.origin.x + window_width / 2.0, bounds.origin.y + window_height / 2.0);
CGWarpMouseCursorPosition(window_center_global_coordinates);
// Without this line there is a short but obvious delay after centering the cursor before it can
// be moved again
CGAssociateMouseAndMouseCursorPosition(true);
g_controller_interface.SetMouseCenteringRequested(false);
}
else
{
CGEventRef event = CGEventCreate(nil);
CGPoint loc = CGEventGetLocation(event);
CFRelease(event);
const auto window_scale = g_controller_interface.GetWindowInputScale();
loc.x -= bounds.origin.x;
loc.y -= bounds.origin.y;
m_cursor.x = (loc.x / window_width * 2 - 1.0) * window_scale.x;
m_cursor.y = (loc.y / window_height * 2 - 1.0) * window_scale.y;
}
}
std::string KeyboardAndMouse::GetName() const