Improve allocation of workspace controls

Fix a bug in the computation of the zoomed-out scale and use a StBin
instead of an unnecessary StBoxLayout. Using the StBin will allow
correct width-for-height behavior for the controls.

https://bugzilla.gnome.org/show_bug.cgi?id=641879
This commit is contained in:
Owen W. Taylor 2011-02-09 18:54:46 -05:00
parent ae5131f902
commit 630f0f0ac8

View File

@ -594,8 +594,9 @@ WorkspacesDisplay.prototype = {
this.actor.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight)); this.actor.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight));
this.actor.connect('allocate', Lang.bind(this, this._allocate)); this.actor.connect('allocate', Lang.bind(this, this._allocate));
let controls = new St.BoxLayout({ vertical: true, let controls = new St.Bin({ style_class: 'workspace-controls',
style_class: 'workspace-controls' }); request_mode: Clutter.RequestMode.WIDTH_FOR_HEIGHT,
y_align: St.Align.START });
this._controls = controls; this._controls = controls;
this.actor.add_actor(controls); this.actor.add_actor(controls);
@ -605,7 +606,7 @@ WorkspacesDisplay.prototype = {
Lang.bind(this, this._onControlsHoverChanged)); Lang.bind(this, this._onControlsHoverChanged));
this._thumbnailsBox = new WorkspaceThumbnail.ThumbnailsBox(); this._thumbnailsBox = new WorkspaceThumbnail.ThumbnailsBox();
controls.add(this._thumbnailsBox.actor, { expand: false }); controls.add_actor(this._thumbnailsBox.actor);
this.workspacesView = null; this.workspacesView = null;
@ -638,7 +639,7 @@ WorkspacesDisplay.prototype = {
let totalWidth = totalAllocation.x2 - totalAllocation.x1; let totalWidth = totalAllocation.x2 - totalAllocation.x1;
let totalHeight = totalAllocation.y2 - totalAllocation.y1; let totalHeight = totalAllocation.y2 - totalAllocation.y1;
let [controlsMin, controlsNatural] = this._controls.get_preferred_width(-1); let [controlsMin, controlsNatural] = this._controls.get_preferred_width(totalHeight);
let controlsReserved = controlsNatural * (1 - CONTROLS_POP_IN_FRACTION); let controlsReserved = controlsNatural * (1 - CONTROLS_POP_IN_FRACTION);
totalWidth -= controlsReserved; totalWidth -= controlsReserved;
@ -664,7 +665,7 @@ WorkspacesDisplay.prototype = {
if (rtl) if (rtl)
x += controlsReserved; x += controlsReserved;
let zoomScale = (totalWidth - controlsNatural) / totalWidth; let zoomScale = (totalWidth - (controlsNatural - controlsReserved)) / totalWidth;
let newView = new WorkspacesView(width, height, x, y, zoomScale, this._workspaces); let newView = new WorkspacesView(width, height, x, y, zoomScale, this._workspaces);
if (this.workspacesView) if (this.workspacesView)