workspace: Scale slots to current workspace size when layout is frozen

The transition from the overview freezes the workspace layout at the
start of the animation, which means that the calculated window slots
remain the same while the workspace itslef grows. This causes the
windows to appear slightly shrunk in comparison to the workspace and
shifted to the top left. This is especially noticeable during the
beginning of the animation when there is more weight on the slots than
the original window position and if there are not that many open
windows.

Unfreezing the layout for this transition is not possible, because it
would cause issues with newly opened windows abruptly changing the
layout when the animation happens after starting a new app.

This change instead tries to scale the frozen layout to the current
workspace size. While this is not entirely correct, because this scales
the spacing between the slots as well, it is still more accurate than
the completely unscaled slots.

Fixes: https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/4616
Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1980>
This commit is contained in:
Sebastian Keller 2021-09-18 17:01:21 +02:00 committed by Marge Bot
parent fc4f9f61fa
commit 6d3df381b3

View File

@ -672,10 +672,13 @@ var WorkspaceLayout = GObject.registerClass({
layoutChanged = true; layoutChanged = true;
} }
if (layoutChanged || containerAllocationChanged) if (layoutChanged || containerAllocationChanged) {
this._windowSlots = this._getWindowSlots(box.copy()); this._windowSlotsBox = box.copy();
this._windowSlots = this._getWindowSlots(this._windowSlotsBox);
}
} }
const slotsScale = box.get_width() / this._windowSlotsBox.get_width();
const workareaX = this._workarea.x; const workareaX = this._workarea.x;
const workareaY = this._workarea.y; const workareaY = this._workarea.y;
const workareaWidth = this._workarea.width; const workareaWidth = this._workarea.width;
@ -691,6 +694,11 @@ var WorkspaceLayout = GObject.registerClass({
if (!child.visible) if (!child.visible)
continue; continue;
x *= slotsScale;
y *= slotsScale;
width *= slotsScale;
height *= slotsScale;
const windowInfo = this._windows.get(child); const windowInfo = this._windows.get(child);
let workspaceBoxX, workspaceBoxY; let workspaceBoxX, workspaceBoxY;