mirror of
https://github.com/hyprwm/Hyprland
synced 2024-11-25 19:26:00 +01:00
Now monitor focus uses same code as change workspace
with correct cursor warping
This commit is contained in:
parent
29d017f54b
commit
47bc01bfca
1 changed files with 17 additions and 33 deletions
|
@ -187,27 +187,7 @@ bool CKeybindManager::tryMoveFocusToMonitor(CMonitor* monitor) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto PWORKSPACE = g_pCompositor->getWorkspaceByID(g_pCompositor->m_pLastMonitor->activeWorkspace);
|
changeworkspace(std::to_string(monitor->activeWorkspace));
|
||||||
const auto PNEWMAINWORKSPACE = g_pCompositor->getWorkspaceByID(monitor->activeWorkspace);
|
|
||||||
|
|
||||||
g_pCompositor->setActiveMonitor(monitor);
|
|
||||||
g_pCompositor->deactivateAllWLRWorkspaces(PNEWMAINWORKSPACE->m_pWlrHandle);
|
|
||||||
PNEWMAINWORKSPACE->setActive(true);
|
|
||||||
PNEWMAINWORKSPACE->rememberPrevWorkspace(PWORKSPACE);
|
|
||||||
|
|
||||||
const auto PNEWWORKSPACE = monitor->specialWorkspaceID != 0 ? g_pCompositor->getWorkspaceByID(monitor->specialWorkspaceID) : PNEWMAINWORKSPACE;
|
|
||||||
|
|
||||||
const auto PNEWWINDOW = PNEWWORKSPACE->getLastFocusedWindow();
|
|
||||||
if (PNEWWINDOW) {
|
|
||||||
g_pCompositor->focusWindow(PNEWWINDOW);
|
|
||||||
Vector2D middle = PNEWWINDOW->m_vRealPosition.goalv() + PNEWWINDOW->m_vRealSize.goalv() / 2.f;
|
|
||||||
g_pCompositor->warpCursorTo(middle);
|
|
||||||
} else {
|
|
||||||
g_pCompositor->focusWindow(nullptr);
|
|
||||||
Vector2D middle = monitor->vecPosition + monitor->vecSize / 2.f;
|
|
||||||
g_pCompositor->warpCursorTo(middle);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -792,14 +772,16 @@ void CKeybindManager::changeworkspace(std::string args) {
|
||||||
PMONITORWORKSPACEOWNER->changeWorkspace(pWorkspaceToChangeTo);
|
PMONITORWORKSPACEOWNER->changeWorkspace(pWorkspaceToChangeTo);
|
||||||
|
|
||||||
if (PMONITOR != PMONITORWORKSPACEOWNER) {
|
if (PMONITOR != PMONITORWORKSPACEOWNER) {
|
||||||
g_pCompositor->warpCursorTo(PMONITORWORKSPACEOWNER->vecPosition + PMONITORWORKSPACEOWNER->vecSize / 2.f);
|
auto PNEWWINDOW = pWorkspaceToChangeTo->getLastFocusedWindow();
|
||||||
|
if (!PNEWWINDOW)
|
||||||
|
PNEWWINDOW = g_pCompositor->getFirstWindowOnWorkspace(pWorkspaceToChangeTo->m_iID);
|
||||||
|
|
||||||
g_pCompositor->setActiveMonitor(PMONITORWORKSPACEOWNER);
|
g_pCompositor->setActiveMonitor(PMONITORWORKSPACEOWNER);
|
||||||
if (const auto PLASTWINDOW = pWorkspaceToChangeTo->getLastFocusedWindow(); PLASTWINDOW)
|
g_pCompositor->focusWindow(PNEWWINDOW);
|
||||||
g_pCompositor->focusWindow(PLASTWINDOW);
|
if (PNEWWINDOW)
|
||||||
else if (const auto PFIRSTWINDOW = g_pCompositor->getFirstWindowOnWorkspace(pWorkspaceToChangeTo->m_iID); PFIRSTWINDOW)
|
g_pCompositor->warpCursorTo(PNEWWINDOW->m_vRealPosition.goalv() + PNEWWINDOW->m_vRealSize.goalv() / 2.f);
|
||||||
g_pCompositor->focusWindow(PFIRSTWINDOW);
|
|
||||||
else
|
else
|
||||||
g_pCompositor->focusWindow(nullptr);
|
g_pCompositor->warpCursorTo(PMONITORWORKSPACEOWNER->vecPosition + PMONITORWORKSPACEOWNER->vecSize / 2.f);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
pWorkspaceToChangeTo = g_pCompositor->createNewWorkspace(PCURRENTWORKSPACE->m_sPrevWorkspace.iID, PMONITOR->ID, PCURRENTWORKSPACE->m_sPrevWorkspace.name);
|
pWorkspaceToChangeTo = g_pCompositor->createNewWorkspace(PCURRENTWORKSPACE->m_sPrevWorkspace.iID, PMONITOR->ID, PCURRENTWORKSPACE->m_sPrevWorkspace.name);
|
||||||
|
@ -833,14 +815,16 @@ void CKeybindManager::changeworkspace(std::string args) {
|
||||||
PMONITORWORKSPACEOWNER->changeWorkspace(pWorkspaceToChangeTo);
|
PMONITORWORKSPACEOWNER->changeWorkspace(pWorkspaceToChangeTo);
|
||||||
|
|
||||||
if (PMONITOR != PMONITORWORKSPACEOWNER) {
|
if (PMONITOR != PMONITORWORKSPACEOWNER) {
|
||||||
|
auto PNEWWINDOW = pWorkspaceToChangeTo->getLastFocusedWindow();
|
||||||
|
if (!PNEWWINDOW)
|
||||||
|
PNEWWINDOW = g_pCompositor->getFirstWindowOnWorkspace(pWorkspaceToChangeTo->m_iID);
|
||||||
|
|
||||||
|
g_pCompositor->focusWindow(PNEWWINDOW);
|
||||||
|
if (PNEWWINDOW)
|
||||||
|
g_pCompositor->warpCursorTo(PNEWWINDOW->m_vRealPosition.goalv() + PNEWWINDOW->m_vRealSize.goalv() / 2.f);
|
||||||
|
else
|
||||||
g_pCompositor->warpCursorTo(PMONITORWORKSPACEOWNER->vecPosition + PMONITORWORKSPACEOWNER->vecSize / 2.f);
|
g_pCompositor->warpCursorTo(PMONITORWORKSPACEOWNER->vecPosition + PMONITORWORKSPACEOWNER->vecSize / 2.f);
|
||||||
|
|
||||||
if (const auto PLASTWINDOW = pWorkspaceToChangeTo->getLastFocusedWindow(); PLASTWINDOW)
|
|
||||||
g_pCompositor->focusWindow(PLASTWINDOW);
|
|
||||||
else if (const auto PFIRSTWINDOW = g_pCompositor->getFirstWindowOnWorkspace(pWorkspaceToChangeTo->m_iID); PFIRSTWINDOW)
|
|
||||||
g_pCompositor->focusWindow(PFIRSTWINDOW);
|
|
||||||
else
|
|
||||||
g_pCompositor->focusWindow(nullptr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pWorkspaceToChangeTo->m_sPrevWorkspace = {PCURRENTWORKSPACE->m_iID, PCURRENTWORKSPACE->m_szName};
|
pWorkspaceToChangeTo->m_sPrevWorkspace = {PCURRENTWORKSPACE->m_iID, PCURRENTWORKSPACE->m_szName};
|
||||||
|
|
Loading…
Reference in a new issue