mirror of
https://github.com/hyprwm/Hyprland
synced 2025-01-10 23:09:50 +01:00
master: replace always_center_master with slave_count_for_center_master (#8871)
- Replaced boolean config parameter `always_center_master` to an integer value `slave_count_for_center_master` for more control on when to center master window. - Also updated configuration parameter, type, description and related internal variable. New description: **when using orientation=center, make the master window centered only when at least this many slave windows are open. (Set 0 to always_center_master)** This effects center orientation of master layout. Now, user can control when the master window would be centered
This commit is contained in:
parent
5b37d53992
commit
fde569db65
3 changed files with 19 additions and 19 deletions
|
@ -1603,10 +1603,10 @@ inline static const std::vector<SConfigOptionDescription> CONFIG_OPTIONS = {
|
||||||
.data = SConfigOptionDescription::SBoolData{true},
|
.data = SConfigOptionDescription::SBoolData{true},
|
||||||
},
|
},
|
||||||
SConfigOptionDescription{
|
SConfigOptionDescription{
|
||||||
.value = "master:always_center_master",
|
.value = "master:slave_count_for_center_master",
|
||||||
.description = "when using orientation=center, keep the master window centered, even when it is the only window in the workspace.",
|
.description = "when using orientation=center, make the master window centered only when at least this many slave windows are open. (Set 0 to always_center_master)",
|
||||||
.type = CONFIG_OPTION_BOOL,
|
.type = CONFIG_OPTION_INT,
|
||||||
.data = SConfigOptionDescription::SBoolData{false},
|
.data = SConfigOptionDescription::SRangeData{2, 0, 10}, //##TODO RANGE?
|
||||||
},
|
},
|
||||||
SConfigOptionDescription{
|
SConfigOptionDescription{
|
||||||
.value = "master:center_ignores_reserved",
|
.value = "master:center_ignores_reserved",
|
||||||
|
|
|
@ -477,7 +477,7 @@ CConfigManager::CConfigManager() {
|
||||||
m_pConfig->addConfigValue("master:special_scale_factor", {1.f});
|
m_pConfig->addConfigValue("master:special_scale_factor", {1.f});
|
||||||
m_pConfig->addConfigValue("master:mfact", {0.55f});
|
m_pConfig->addConfigValue("master:mfact", {0.55f});
|
||||||
m_pConfig->addConfigValue("master:new_status", {"slave"});
|
m_pConfig->addConfigValue("master:new_status", {"slave"});
|
||||||
m_pConfig->addConfigValue("master:always_center_master", Hyprlang::INT{0});
|
m_pConfig->addConfigValue("master:slave_count_for_center_master", Hyprlang::INT{2});
|
||||||
m_pConfig->addConfigValue("master:center_ignores_reserved", Hyprlang::INT{0});
|
m_pConfig->addConfigValue("master:center_ignores_reserved", Hyprlang::INT{0});
|
||||||
m_pConfig->addConfigValue("master:new_on_active", {"none"});
|
m_pConfig->addConfigValue("master:new_on_active", {"none"});
|
||||||
m_pConfig->addConfigValue("master:new_on_top", Hyprlang::INT{0});
|
m_pConfig->addConfigValue("master:new_on_top", Hyprlang::INT{0});
|
||||||
|
|
|
@ -327,7 +327,7 @@ void CHyprMasterLayout::calculateWorkspace(PHLWORKSPACE pWorkspace) {
|
||||||
|
|
||||||
eOrientation orientation = getDynamicOrientation(pWorkspace);
|
eOrientation orientation = getDynamicOrientation(pWorkspace);
|
||||||
bool centerMasterWindow = false;
|
bool centerMasterWindow = false;
|
||||||
static auto ALWAYSCENTER = CConfigValue<Hyprlang::INT>("master:always_center_master");
|
static auto SLAVECOUNTFORCENTER = CConfigValue<Hyprlang::INT>("master:slave_count_for_center_master");
|
||||||
static auto PIGNORERESERVED = CConfigValue<Hyprlang::INT>("master:center_ignores_reserved");
|
static auto PIGNORERESERVED = CConfigValue<Hyprlang::INT>("master:center_ignores_reserved");
|
||||||
static auto PSMARTRESIZING = CConfigValue<Hyprlang::INT>("master:smart_resizing");
|
static auto PSMARTRESIZING = CConfigValue<Hyprlang::INT>("master:smart_resizing");
|
||||||
|
|
||||||
|
@ -338,7 +338,7 @@ void CHyprMasterLayout::calculateWorkspace(PHLWORKSPACE pWorkspace) {
|
||||||
const auto WSPOS = PMONITOR->vecPosition + PMONITOR->vecReservedTopLeft;
|
const auto WSPOS = PMONITOR->vecPosition + PMONITOR->vecReservedTopLeft;
|
||||||
|
|
||||||
if (orientation == ORIENTATION_CENTER) {
|
if (orientation == ORIENTATION_CENTER) {
|
||||||
if (STACKWINDOWS >= 2 || (*ALWAYSCENTER == 1)) {
|
if (STACKWINDOWS >= *SLAVECOUNTFORCENTER) {
|
||||||
centerMasterWindow = true;
|
centerMasterWindow = true;
|
||||||
} else {
|
} else {
|
||||||
orientation = ORIENTATION_LEFT;
|
orientation = ORIENTATION_LEFT;
|
||||||
|
@ -709,13 +709,9 @@ void CHyprMasterLayout::resizeActiveWindow(const Vector2D& pixResize, eRectCorne
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto PMONITOR = PWINDOW->m_pMonitor.lock();
|
const auto PMONITOR = PWINDOW->m_pMonitor.lock();
|
||||||
static auto ALWAYSCENTER = CConfigValue<Hyprlang::INT>("master:always_center_master");
|
static auto SLAVECOUNTFORCENTER = CConfigValue<Hyprlang::INT>("master:slave_count_for_center_master");
|
||||||
static auto PSMARTRESIZING = CConfigValue<Hyprlang::INT>("master:smart_resizing");
|
static auto PSMARTRESIZING = CConfigValue<Hyprlang::INT>("master:smart_resizing");
|
||||||
|
|
||||||
eOrientation orientation = getDynamicOrientation(PWINDOW->m_pWorkspace);
|
|
||||||
bool centered = orientation == ORIENTATION_CENTER && (*ALWAYSCENTER == 1);
|
|
||||||
double delta = 0;
|
|
||||||
|
|
||||||
const bool DISPLAYBOTTOM = STICKS(PWINDOW->m_vPosition.y + PWINDOW->m_vSize.y, PMONITOR->vecPosition.y + PMONITOR->vecSize.y - PMONITOR->vecReservedBottomRight.y);
|
const bool DISPLAYBOTTOM = STICKS(PWINDOW->m_vPosition.y + PWINDOW->m_vSize.y, PMONITOR->vecPosition.y + PMONITOR->vecSize.y - PMONITOR->vecReservedBottomRight.y);
|
||||||
const bool DISPLAYRIGHT = STICKS(PWINDOW->m_vPosition.x + PWINDOW->m_vSize.x, PMONITOR->vecPosition.x + PMONITOR->vecSize.x - PMONITOR->vecReservedBottomRight.x);
|
const bool DISPLAYRIGHT = STICKS(PWINDOW->m_vPosition.x + PWINDOW->m_vSize.x, PMONITOR->vecPosition.x + PMONITOR->vecSize.x - PMONITOR->vecReservedBottomRight.x);
|
||||||
const bool DISPLAYTOP = STICKS(PWINDOW->m_vPosition.y, PMONITOR->vecPosition.y + PMONITOR->vecReservedTopLeft.y);
|
const bool DISPLAYTOP = STICKS(PWINDOW->m_vPosition.y, PMONITOR->vecPosition.y + PMONITOR->vecReservedTopLeft.y);
|
||||||
|
@ -729,6 +725,10 @@ void CHyprMasterLayout::resizeActiveWindow(const Vector2D& pixResize, eRectCorne
|
||||||
const auto WINDOWS = getNodesOnWorkspace(PNODE->workspaceID);
|
const auto WINDOWS = getNodesOnWorkspace(PNODE->workspaceID);
|
||||||
const auto STACKWINDOWS = WINDOWS - MASTERS;
|
const auto STACKWINDOWS = WINDOWS - MASTERS;
|
||||||
|
|
||||||
|
eOrientation orientation = getDynamicOrientation(PWINDOW->m_pWorkspace);
|
||||||
|
bool centered = orientation == ORIENTATION_CENTER && (STACKWINDOWS >= *SLAVECOUNTFORCENTER);
|
||||||
|
double delta = 0;
|
||||||
|
|
||||||
if (getNodesOnWorkspace(PWINDOW->workspaceID()) == 1 && !centered)
|
if (getNodesOnWorkspace(PWINDOW->workspaceID()) == 1 && !centered)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -741,7 +741,7 @@ void CHyprMasterLayout::resizeActiveWindow(const Vector2D& pixResize, eRectCorne
|
||||||
case ORIENTATION_TOP: delta = pixResize.y / PMONITOR->vecSize.y; break;
|
case ORIENTATION_TOP: delta = pixResize.y / PMONITOR->vecSize.y; break;
|
||||||
case ORIENTATION_CENTER:
|
case ORIENTATION_CENTER:
|
||||||
delta = pixResize.x / PMONITOR->vecSize.x;
|
delta = pixResize.x / PMONITOR->vecSize.x;
|
||||||
if (WINDOWS > 2 || *ALWAYSCENTER) {
|
if (STACKWINDOWS >= *SLAVECOUNTFORCENTER) {
|
||||||
if (!NONE || !PNODE->isMaster)
|
if (!NONE || !PNODE->isMaster)
|
||||||
delta *= 2;
|
delta *= 2;
|
||||||
if ((!PNODE->isMaster && DISPLAYLEFT) || (PNODE->isMaster && LEFT && *PSMARTRESIZING))
|
if ((!PNODE->isMaster && DISPLAYLEFT) || (PNODE->isMaster && LEFT && *PSMARTRESIZING))
|
||||||
|
|
Loading…
Reference in a new issue