mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-09 02:45:58 +01:00
input: hold focus on mouse buttons
This commit is contained in:
parent
c2b25f4701
commit
0fc145c52c
3 changed files with 57 additions and 0 deletions
|
@ -2150,11 +2150,28 @@ void CCompositor::closeWindow(CWindow* pWindow) {
|
||||||
}
|
}
|
||||||
|
|
||||||
SLayerSurface* CCompositor::getLayerSurfaceFromSurface(wlr_surface* pSurface) {
|
SLayerSurface* CCompositor::getLayerSurfaceFromSurface(wlr_surface* pSurface) {
|
||||||
|
std::pair<wlr_surface*, bool> result = {pSurface, false};
|
||||||
|
|
||||||
for (auto& m : m_vMonitors) {
|
for (auto& m : m_vMonitors) {
|
||||||
for (auto& lsl : m->m_aLayerSurfaceLayers) {
|
for (auto& lsl : m->m_aLayerSurfaceLayers) {
|
||||||
for (auto& ls : lsl) {
|
for (auto& ls : lsl) {
|
||||||
if (ls->layerSurface && ls->layerSurface->surface == pSurface)
|
if (ls->layerSurface && ls->layerSurface->surface == pSurface)
|
||||||
return ls.get();
|
return ls.get();
|
||||||
|
|
||||||
|
static auto iter = [](wlr_surface* surf, int x, int y, void* data) -> void {
|
||||||
|
if (surf == ((std::pair<wlr_surface*, bool>*)data)->first) {
|
||||||
|
*(bool*)data = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!ls->layerSurface || !ls->mapped)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
wlr_surface_for_each_surface(ls->layerSurface->surface, iter, &result);
|
||||||
|
|
||||||
|
if (result.second)
|
||||||
|
return ls.get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -145,6 +145,32 @@ void CInputManager::mouseMoveUnified(uint32_t time, bool refocus) {
|
||||||
// update stuff
|
// update stuff
|
||||||
updateDragIcon();
|
updateDragIcon();
|
||||||
|
|
||||||
|
if (!m_sDrag.drag && !m_lCurrentlyHeldButtons.empty() && g_pCompositor->m_pLastFocus) {
|
||||||
|
if (m_bLastFocusOnLS) {
|
||||||
|
foundSurface = g_pCompositor->m_pLastFocus;
|
||||||
|
pFoundLayerSurface = g_pCompositor->getLayerSurfaceFromSurface(foundSurface);
|
||||||
|
if (pFoundLayerSurface) {
|
||||||
|
surfacePos = g_pCompositor->getLayerSurfaceFromSurface(foundSurface)->position;
|
||||||
|
m_bFocusHeldByButtons = true;
|
||||||
|
m_bRefocusHeldByButtons = refocus;
|
||||||
|
} else {
|
||||||
|
// ?
|
||||||
|
foundSurface = nullptr;
|
||||||
|
pFoundLayerSurface = nullptr;
|
||||||
|
}
|
||||||
|
} else if (g_pCompositor->m_pLastWindow) {
|
||||||
|
foundSurface = g_pCompositor->m_pLastFocus;
|
||||||
|
|
||||||
|
if (!g_pCompositor->m_pLastWindow->m_bIsX11)
|
||||||
|
g_pCompositor->vectorWindowToSurface(mouseCoords, g_pCompositor->m_pLastWindow, surfaceCoords);
|
||||||
|
else
|
||||||
|
surfacePos = g_pCompositor->m_pLastWindow->m_vRealPosition.vec();
|
||||||
|
|
||||||
|
m_bFocusHeldByButtons = true;
|
||||||
|
m_bRefocusHeldByButtons = refocus;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
g_pLayoutManager->getCurrentLayout()->onMouseMove(getMouseCoordsInternal());
|
g_pLayoutManager->getCurrentLayout()->onMouseMove(getMouseCoordsInternal());
|
||||||
|
|
||||||
if (PMONITOR && PMONITOR != g_pCompositor->m_pLastMonitor && (*PMOUSEFOCUSMON || refocus)) {
|
if (PMONITOR && PMONITOR != g_pCompositor->m_pLastMonitor && (*PMOUSEFOCUSMON || refocus)) {
|
||||||
|
@ -391,6 +417,16 @@ void CInputManager::onMouseButton(wlr_pointer_button_event* e) {
|
||||||
case CLICKMODE_KILL: processMouseDownKill(e); break;
|
case CLICKMODE_KILL: processMouseDownKill(e); break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_bFocusHeldByButtons && m_lCurrentlyHeldButtons.empty() && e->state == WLR_BUTTON_RELEASED) {
|
||||||
|
if (m_bRefocusHeldByButtons)
|
||||||
|
refocus();
|
||||||
|
else
|
||||||
|
simulateMouseMovement();
|
||||||
|
|
||||||
|
m_bFocusHeldByButtons = false;
|
||||||
|
m_bRefocusHeldByButtons = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CInputManager::processMouseRequest(wlr_seat_pointer_request_set_cursor_event* e) {
|
void CInputManager::processMouseRequest(wlr_seat_pointer_request_set_cursor_event* e) {
|
||||||
|
|
|
@ -202,6 +202,10 @@ class CInputManager {
|
||||||
SLayerSurface* m_pFoundLSToFocus = nullptr;
|
SLayerSurface* m_pFoundLSToFocus = nullptr;
|
||||||
CWindow* m_pFoundWindowToFocus = nullptr;
|
CWindow* m_pFoundWindowToFocus = nullptr;
|
||||||
|
|
||||||
|
// for holding focus on buttons held
|
||||||
|
bool m_bFocusHeldByButtons = false;
|
||||||
|
bool m_bRefocusHeldByButtons = false;
|
||||||
|
|
||||||
// for releasing mouse buttons
|
// for releasing mouse buttons
|
||||||
std::list<uint32_t> m_lCurrentlyHeldButtons;
|
std::list<uint32_t> m_lCurrentlyHeldButtons;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue