core: add auto-center arrangements (#10527)
Signed-off-by: Nikolaos Karaolidis <nick@karaolidis.com>
This commit is contained in:
parent
ddb9f8394d
commit
90d0b8ecae
3 changed files with 40 additions and 2 deletions
|
|
@ -2890,6 +2890,30 @@ void CCompositor::arrangeMonitors() {
|
|||
case eAutoDirs::DIR_AUTO_LEFT: newPosition.x = maxXOffsetLeft - m->m_size.x; break;
|
||||
case eAutoDirs::DIR_AUTO_RIGHT:
|
||||
case eAutoDirs::DIR_AUTO_NONE: newPosition.x = maxXOffsetRight; break;
|
||||
case eAutoDirs::DIR_AUTO_CENTER_UP: {
|
||||
int width = maxXOffsetRight - maxXOffsetLeft;
|
||||
newPosition.y = maxYOffsetUp - m->m_size.y;
|
||||
newPosition.x = maxXOffsetLeft + (width - m->m_size.x) / 2;
|
||||
break;
|
||||
}
|
||||
case eAutoDirs::DIR_AUTO_CENTER_DOWN: {
|
||||
int width = maxXOffsetRight - maxXOffsetLeft;
|
||||
newPosition.y = maxYOffsetDown;
|
||||
newPosition.x = maxXOffsetLeft + (width - m->m_size.x) / 2;
|
||||
break;
|
||||
}
|
||||
case eAutoDirs::DIR_AUTO_CENTER_LEFT: {
|
||||
int height = maxYOffsetDown - maxYOffsetUp;
|
||||
newPosition.x = maxXOffsetLeft - m->m_size.x;
|
||||
newPosition.y = maxYOffsetUp + (height - m->m_size.y) / 2;
|
||||
break;
|
||||
}
|
||||
case eAutoDirs::DIR_AUTO_CENTER_RIGHT: {
|
||||
int height = maxYOffsetDown - maxYOffsetUp;
|
||||
newPosition.x = maxXOffsetRight;
|
||||
newPosition.y = maxYOffsetUp + (height - m->m_size.y) / 2;
|
||||
break;
|
||||
}
|
||||
default: UNREACHABLE();
|
||||
}
|
||||
Debug::log(LOG, "arrangeMonitors: {} auto {:j}", m->m_name, m->m_position);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue