input-capture: inhibit inputs

This commit is contained in:
Gwilherm Folliot 2024-09-26 08:47:21 +02:00
parent 62c5ee5f19
commit fb749a680e
No known key found for this signature in database
GPG key ID: 90236D3623DCD660
4 changed files with 40 additions and 18 deletions

View file

@ -705,7 +705,9 @@ void CPointerManager::move(const Vector2D& deltaLogical) {
PROTO::inputCapture->sendAbsoluteMotion(newPos, deltaLogical);
//TODO: Inhibit inputs
if (PROTO::inputCapture->isCaptured())
return;
warpTo(newPos);
}

View file

@ -100,7 +100,9 @@ void CInputManager::onMouseMoved(IPointer::SMotionEvent e) {
g_pPointerManager->move(DELTA);
//TODO: Inhibit inputs
if (PROTO::inputCapture->isCaptured())
return;
mouseMoveUnified(e.timeMs, false, e.mouse);
m_tmrLastCursorMovement.reset();
@ -549,7 +551,9 @@ void CInputManager::onMouseButton(IPointer::SButtonEvent e) {
PROTO::inputCapture->sendButton(e.button, (hyprlandInputCaptureManagerV1ButtonState)e.state);
//TODO: Inhibit inputs
if (PROTO::inputCapture->isCaptured())
return;
m_tmrLastCursorMovement.reset();
if (e.state == WL_POINTER_BUTTON_STATE_PRESSED) {
@ -793,8 +797,7 @@ void CInputManager::onMouseWheel(IPointer::SAxisEvent e) {
else if (e.delta == 0)
PROTO::inputCapture->sendAxisStop((hyprlandInputCaptureManagerV1Axis)e.axis);
//TODO: Inhibit inputs
bool passEvent = g_pKeybindManager->onAxisEvent(e);
bool passEvent = !PROTO::inputCapture->isCaptured() && g_pKeybindManager->onAxisEvent(e);
if (!passEvent)
return;
@ -877,7 +880,9 @@ void CInputManager::onMouseWheel(IPointer::SAxisEvent e) {
void CInputManager::onMouseFrame() {
PROTO::inputCapture->sendFrame();
//TODO: Inhibit inputs
if (PROTO::inputCapture->isCaptured())
return;
g_pSeatManager->sendPointerFrame();
}
@ -1340,11 +1345,10 @@ void CInputManager::onKeyboardKey(std::any event, SP<IKeyboard> pKeyboard) {
const auto EMAP = std::unordered_map<std::string, std::any>{{"keyboard", pKeyboard}, {"event", event}};
EMIT_HOOK_EVENT_CANCELLABLE("keyPress", EMAP);
bool passEvent = DISALLOWACTION || g_pKeybindManager->onKeyEvent(event, pKeyboard);
bool passEvent = !PROTO::inputCapture->isCaptured() && (DISALLOWACTION || g_pKeybindManager->onKeyEvent(event, pKeyboard));
auto e = std::any_cast<IKeyboard::SKeyEvent>(event);
//TODO: Inhibit inputs
PROTO::inputCapture->sendKey(e.keycode, (hyprlandInputCaptureManagerV1KeyState)e.state);
if (passEvent) {

View file

@ -5,7 +5,7 @@
#include <wayland-util.h>
CInputCaptureProtocol::CInputCaptureProtocol(const wl_interface* iface, const int& ver, const std::string& name) : IWaylandProtocol(iface, ver, name) {
;
active = false;
}
void CInputCaptureProtocol::bindManager(wl_client* client, void* data, uint32_t ver, uint32_t id) {
@ -21,9 +21,19 @@ void CInputCaptureProtocol::onManagerResourceDestroy(wl_resource* res) {
std::erase_if(m_vManagers, [&](const auto& other) { return other->resource() == res; });
}
void CInputCaptureProtocol::onCapture(CHyprlandInputCaptureManagerV1* pMgr) {}
void CInputCaptureProtocol::onCapture(CHyprlandInputCaptureManagerV1* pMgr) {
Debug::log(LOG, "[input-capture] Input captured");
active = true;
}
void CInputCaptureProtocol::onRelease(CHyprlandInputCaptureManagerV1* pMgr) {}
void CInputCaptureProtocol::onRelease(CHyprlandInputCaptureManagerV1* pMgr) {
Debug::log(LOG, "[input-capture] Input released");
active = false;
}
bool CInputCaptureProtocol::isCaptured() {
return active;
}
void CInputCaptureProtocol::sendAbsoluteMotion(const Vector2D& absolutePosition, const Vector2D& delta) {
for (const UP<CHyprlandInputCaptureManagerV1>& manager : m_vManagers) {

View file

@ -8,6 +8,10 @@ class CInputCaptureProtocol : public IWaylandProtocol {
public:
CInputCaptureProtocol(const wl_interface* iface, const int& ver, const std::string& name);
virtual void bindManager(wl_client* client, void* data, uint32_t ver, uint32_t id);
bool isCaptured();
//
void sendAbsoluteMotion(const Vector2D& absolutePosition, const Vector2D& delta);
void sendKey(uint32_t keyCode, hyprlandInputCaptureManagerV1KeyState state);
void sendButton(uint32_t button, hyprlandInputCaptureManagerV1ButtonState state);
@ -18,6 +22,8 @@ class CInputCaptureProtocol : public IWaylandProtocol {
void sendFrame();
private:
bool active;
void onManagerResourceDestroy(wl_resource* res);
void onCapture(CHyprlandInputCaptureManagerV1* pMgr);
void onRelease(CHyprlandInputCaptureManagerV1* pMgr);