mirror of
https://github.com/hyprwm/Hyprland
synced 2024-12-23 13:09:50 +01:00
keybinds: movewindow to screen edge for floating windows (#3245)
* movewindow to screen edge for floating windows * review changes * constify vars --------- Co-authored-by: Leeman <lstrout@enlj.com> Co-authored-by: vaxerski <vaxry@vaxry.net>
This commit is contained in:
parent
e96e0dc02d
commit
99fac59938
1 changed files with 18 additions and 0 deletions
|
@ -1136,6 +1136,24 @@ void CKeybindManager::moveActiveTo(std::string args) {
|
||||||
if (!PLASTWINDOW || PLASTWINDOW->m_bIsFullscreen)
|
if (!PLASTWINDOW || PLASTWINDOW->m_bIsFullscreen)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (PLASTWINDOW->m_bIsFloating) {
|
||||||
|
auto vPos = PLASTWINDOW->m_vRealPosition.goalv();
|
||||||
|
const auto PMONITOR = g_pCompositor->getMonitorFromID(PLASTWINDOW->m_iMonitorID);
|
||||||
|
const auto BORDERSIZE = PLASTWINDOW->getRealBorderSize();
|
||||||
|
|
||||||
|
switch (arg) {
|
||||||
|
case 'l': vPos.x = PMONITOR->vecReservedTopLeft.x + BORDERSIZE; break;
|
||||||
|
case 'r': vPos.x = PMONITOR->vecSize.x - PMONITOR->vecReservedBottomRight.x - PLASTWINDOW->m_vRealSize.goalv().x - BORDERSIZE; break;
|
||||||
|
case 't':
|
||||||
|
case 'u': vPos.y = PMONITOR->vecReservedTopLeft.y + BORDERSIZE; break;
|
||||||
|
case 'b':
|
||||||
|
case 'd': vPos.y = PMONITOR->vecSize.y - PMONITOR->vecReservedBottomRight.y - PLASTWINDOW->m_vRealSize.goalv().y - BORDERSIZE; break;
|
||||||
|
}
|
||||||
|
|
||||||
|
PLASTWINDOW->m_vRealPosition = vPos + PMONITOR->vecPosition;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// If the window to change to is on the same workspace, switch them
|
// If the window to change to is on the same workspace, switch them
|
||||||
const auto PWINDOWTOCHANGETO = g_pCompositor->getWindowInDirection(PLASTWINDOW, arg);
|
const auto PWINDOWTOCHANGETO = g_pCompositor->getWindowInDirection(PLASTWINDOW, arg);
|
||||||
if (PWINDOWTOCHANGETO) {
|
if (PWINDOWTOCHANGETO) {
|
||||||
|
|
Loading…
Reference in a new issue