awful.wibox: update strut on wibox attachement

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Julien Danjou 2009-08-18 15:45:17 +02:00
parent a7a1ead538
commit d6fd7f1116
6 changed files with 32 additions and 93 deletions

View File

@ -11,7 +11,6 @@ local capi = { screen = screen, client = client }
local tag = require("awful.tag") local tag = require("awful.tag")
local util = require("awful.util") local util = require("awful.util")
local suit = require("awful.layout.suit") local suit = require("awful.layout.suit")
local wibox = require("awful.wibox")
local ascreen = require("awful.screen") local ascreen = require("awful.screen")
local capi = { local capi = {
screen = screen, screen = screen,
@ -64,7 +63,7 @@ end
-- @param screen The screen to arrange. -- @param screen The screen to arrange.
function arrange(screen) function arrange(screen)
local p = {} local p = {}
p.workarea = wibox.get_workarea(screen) p.workarea = capi.screen[screen].workarea
-- Handle padding -- Handle padding
local padding = ascreen.padding(screen) local padding = ascreen.padding(screen)
if padding then if padding then

View File

@ -25,7 +25,6 @@ local util = require("awful.util")
local tags = require("awful.tag") local tags = require("awful.tag")
local layout = require("awful.widget.layout") local layout = require("awful.widget.layout")
local awbeautiful = require("beautiful") local awbeautiful = require("beautiful")
local awibox = require("awful.wibox")
local tonumber = tonumber local tonumber = tonumber
--- Menu module for awful --- Menu module for awful
@ -257,7 +256,7 @@ function clients(menu)
end end
local function set_coords(menu, screen_idx) local function set_coords(menu, screen_idx)
local s_geometry = awibox.get_workarea(screen_idx) local s_geometry = capi.screen[screen_idx].workarea
local screen_w = s_geometry.x + s_geometry.width local screen_w = s_geometry.x + s_geometry.width
local screen_h = s_geometry.y + s_geometry.height local screen_h = s_geometry.y + s_geometry.height

View File

@ -114,7 +114,7 @@ function client.snap(c, snap, x, y, fixed_x, fixed_y)
geom.y = y or geom.y geom.y = y or geom.y
geom, edge = snap_inside(geom, capi.screen[c.screen].geometry, snap) geom, edge = snap_inside(geom, capi.screen[c.screen].geometry, snap)
geom = snap_inside(geom, awibox.get_workarea(c.screen), snap) geom = snap_inside(geom, capi.screen[c.screen].workarea, snap)
-- Allow certain windows to snap to the edge of the workarea. -- Allow certain windows to snap to the edge of the workarea.
-- Only allow docking to workarea for consistency/to avoid problems. -- Only allow docking to workarea for consistency/to avoid problems.
@ -240,7 +240,7 @@ function client.dragtotag.border(c)
for _, v in ipairs(mouse.buttons) do for _, v in ipairs(mouse.buttons) do
if v then button_down = true end if v then button_down = true end
end end
local wa = awibox.get_workarea(c.screen) local wa = capi.screen[c.screen].workarea
if mouse.x >= wa.x + wa.width then if mouse.x >= wa.x + wa.width then
capi.mouse.coords({ x = wa.x + wa.width - 1 }) capi.mouse.coords({ x = wa.x + wa.width - 1 })
elseif mouse.x <= wa.x then elseif mouse.x <= wa.x then
@ -287,7 +287,7 @@ function wibox.move(w)
w.x = capi.mouse.coords().x + offset.x w.x = capi.mouse.coords().x + offset.x
w.y = capi.mouse.coords().y + offset.y w.y = capi.mouse.coords().y + offset.y
else else
local wa = awibox.get_workarea(capi.mouse.screen) local wa = capi.screen[capi.mouse.screen].workarea
if capi.mouse.coords()["y"] > wa.y + wa.height - 10 then if capi.mouse.coords()["y"] > wa.y + wa.height - 10 then
awibox.set_position(w, "bottom", w.screen) awibox.set_position(w, "bottom", w.screen)
@ -360,7 +360,7 @@ local function client_resize_magnifier(c, corner)
local corner, x, y = client.corner(c, corner) local corner, x, y = client.corner(c, corner)
capi.mouse.coords({ x = x, y = y }) capi.mouse.coords({ x = x, y = y })
local wa = awibox.get_workarea(c.screen) local wa = capi.screen[c.screen].workarea
local center_x = wa.x + wa.width / 2 local center_x = wa.x + wa.width / 2
local center_y = wa.y + wa.height / 2 local center_y = wa.y + wa.height / 2
local maxdist_pow = (wa.width^2 + wa.height^2) / 4 local maxdist_pow = (wa.width^2 + wa.height^2) / 4
@ -383,7 +383,7 @@ local function client_resize_magnifier(c, corner)
end end
local function client_resize_tiled(c, lay) local function client_resize_tiled(c, lay)
local wa = awibox.get_workarea(c.screen) local wa = capi.screen[c.screen].workarea
local mwfact = tag.getmwfact() local mwfact = tag.getmwfact()
local cursor local cursor
local g = c:geometry() local g = c:geometry()

View File

@ -17,7 +17,6 @@ local capi =
} }
local client = require("awful.client") local client = require("awful.client")
local layout = require("awful.layout") local layout = require("awful.layout")
local wibox = require("awful.wibox")
--- Placement module for awful --- Placement module for awful
module("awful.placement") module("awful.placement")
@ -106,7 +105,7 @@ end
function no_offscreen(c) function no_offscreen(c)
local c = c or capi.client.focus local c = c or capi.client.focus
local geometry = c:geometry() local geometry = c:geometry()
local screen_geometry = wibox.get_workarea(c.screen) local screen_geometry = capi.screen[c.screen].workarea
if geometry.x + geometry.width > screen_geometry.x + screen_geometry.width then if geometry.x + geometry.width > screen_geometry.x + screen_geometry.width then
geometry.x = screen_geometry.x + screen_geometry.width - geometry.width geometry.x = screen_geometry.x + screen_geometry.width - geometry.width
@ -128,7 +127,7 @@ end
function no_overlap(c) function no_overlap(c)
local cls = client.visible(c.screen) local cls = client.visible(c.screen)
local curlay = layout.get() local curlay = layout.get()
local areas = { wibox.get_workarea(c.screen) } local areas = { capi.screen[c.screen].workarea }
local geometry = c:geometry() local geometry = c:geometry()
for i, cl in pairs(cls) do for i, cl in pairs(cls) do
if cl ~= c and (client.floating.get(cl) or curlay == layout.suit.floating) then if cl ~= c and (client.floating.get(cl) or curlay == layout.suit.floating) then

View File

@ -25,60 +25,6 @@ module("awful.wibox")
-- It's an array so it is ordered. -- It's an array so it is ordered.
local wiboxes = {} local wiboxes = {}
--- Get the workarea space without wiboxes geometry.
-- @param s The screen number.
-- @return The screen workarea.
function get_workarea(s)
local area = capi.screen[s].workarea
for _, wprop in ipairs(wiboxes) do
if wprop.wibox.visible and wprop.wibox.screen == s then
if wprop.position == "top" then
area.y = area.y + wprop.wibox.height + (2 * wprop.wibox.border_width)
area.height = area.height - (wprop.wibox.height + (2 * wprop.wibox.border_width))
elseif wprop.position == "bottom" then
area.height = area.height - (wprop.wibox.height + (2 * wprop.wibox.border_width))
elseif wprop.position == "left" then
area.x = area.x + wprop.wibox.width + (2 * wprop.wibox.border_width)
area.width = area.width - (wprop.wibox.width + (2 * wprop.wibox.border_width))
elseif wprop.position == "right" then
area.width = area.width - (wprop.wibox.width + (2 * wprop.wibox.border_width))
end
end
end
return area
end
local function compute_area(wibox, position, s)
local s = wibox.screen or s or 1
local area = capi.screen[s].workarea
local ignore = false
for _, wprop in ipairs(wiboxes) do
if wprop.wibox == wibox then
ignore = true
elseif wprop.wibox.visible and wprop.wibox.screen == s
and not (ignore and wprop.position == position) then
if (wprop.position == "right" or wprop.position == "left")
and wprop.position == position then
area.x = area.x + (wibox.width + (2 * wibox.border_width))
elseif wprop.position == "top" then
if position == "top" then
area.y = area.y + (wprop.wibox.height + (2 * wprop.wibox.border_width))
elseif position == "left" or position == "right" then
area.height = area.height - (wprop.wibox.height + (2 * wprop.wibox.border_width))
area.y = area.y + (wprop.wibox.height + (2 * wprop.wibox.border_width))
end
elseif wprop.position == "bottom" then
if position == "bottom" then
area.y = area.y - (wprop.wibox.height + (2 * wprop.wibox.border_width))
elseif position == "left" or position == "right" then
area.height = area.height - (wprop.wibox.height + (2 * wprop.wibox.border_width))
end
end
end
end
return area
end
--- Get a wibox position if it has been set, or return top. --- Get a wibox position if it has been set, or return top.
-- @param wibox The wibox -- @param wibox The wibox
-- @return The wibox position. -- @return The wibox position.
@ -91,13 +37,14 @@ function get_position(wibox)
return "top" return "top"
end end
--- Attach a wibox to a screen at the position. --- Put a wibox on a screen at this position.
-- @param wibox The wibox to attach. -- @param wibox The wibox to attach.
-- @param position The position: top, bottom left or right. -- @param position The position: top, bottom left or right.
-- @param screen If the wibox it not attached to a screen, specified on which -- @param screen If the wibox it not attached to a screen, specified on which
-- screen the position should be set. -- screen the position should be set.
function set_position(wibox, position, screen) function set_position(wibox, position, screen)
local area = compute_area(wibox, position, screen) local screen = screen or wibox.screen or 1
local area = capi.screen[screen].geometry
-- The "length" of a wibox is always chosen to be the optimal size -- The "length" of a wibox is always chosen to be the optimal size
-- (non-floating). -- (non-floating).
@ -170,13 +117,8 @@ function attach(wibox, position)
end end
end end
if position ~= "top" and position ~= "bottom" and position ~= "right" and position ~= "left" then
position = "floating"
end
if not wibox_prop_table then if not wibox_prop_table then
table.insert(wiboxes, table.insert(wiboxes, setmetatable({ wibox = wibox, position = position }, { __mode = 'v' }))
setmetatable({ wibox = wibox, position = position }, { __mode = 'v' }))
else else
wibox_prop_table.position = position wibox_prop_table.position = position
end end
@ -184,10 +126,6 @@ function attach(wibox, position)
wibox:add_signal("property::width", wibox_update_strut) wibox:add_signal("property::width", wibox_update_strut)
wibox:add_signal("property::height", wibox_update_strut) wibox:add_signal("property::height", wibox_update_strut)
if wibox.screen and wibox.visible then
update_all_wiboxes_position()
end
wibox:add_signal("property::screen", call_wibox_position_hook_on_prop_update) wibox:add_signal("property::screen", call_wibox_position_hook_on_prop_update)
wibox:add_signal("property::visible", call_wibox_position_hook_on_prop_update) wibox:add_signal("property::visible", call_wibox_position_hook_on_prop_update)
wibox:add_signal("property::border_width", call_wibox_position_hook_on_prop_update) wibox:add_signal("property::border_width", call_wibox_position_hook_on_prop_update)
@ -200,7 +138,8 @@ end
-- screen where to align. Otherwise 1 is assumed. -- screen where to align. Otherwise 1 is assumed.
function align(wibox, align, screen) function align(wibox, align, screen)
local position = get_position(wibox) local position = get_position(wibox)
local area = compute_area(wibox, position, screen) local screen = screen or wibox.screen or 1
local area = capi.screen[screen].geometry
if position == "right" then if position == "right" then
if align == "right" then if align == "right" then
@ -239,9 +178,12 @@ end
--- Stretch a wibox so it takes all screen width or height. --- Stretch a wibox so it takes all screen width or height.
-- @param wibox The wibox. -- @param wibox The wibox.
function stretch(wibox) -- @param screen The screen to stretch on, or the wibox screen.
function stretch(wibox, screen)
local screen = screen or wibox.screen
if screen then
local position = get_position(wibox) local position = get_position(wibox)
local area = compute_area(wibox, position) local area = capi.screen[screen].workarea
if position == "right" or position == "left" then if position == "right" or position == "left" then
wibox.height = area.height - (2 * wibox.border_width) wibox.height = area.height - (2 * wibox.border_width)
align(wibox, "center") align(wibox, "center")
@ -249,6 +191,7 @@ function stretch(wibox)
wibox.width = area.width - (2 * wibox.border_width) wibox.width = area.width - (2 * wibox.border_width)
align(wibox, "left") align(wibox, "left")
end end
end
end end
--- Create a new wibox and attach it to a screen edge. --- Create a new wibox and attach it to a screen edge.
@ -274,7 +217,7 @@ function new(arg)
if arg.screen then if arg.screen then
local hp = arg.height:match("(%d+)%%") local hp = arg.height:match("(%d+)%%")
if hp then if hp then
arg.height = capi.screen[arg.screen].workarea.height * hp / 100 arg.height = capi.screen[arg.screen].geometry.height * hp / 100
end end
end end
end end
@ -285,7 +228,7 @@ function new(arg)
if arg.screen then if arg.screen then
local wp = arg.width:match("(%d+)%%") local wp = arg.width:match("(%d+)%%")
if wp then if wp then
arg.width = capi.screen[arg.screen].workarea.width * wp / 100 arg.width = capi.screen[arg.screen].geometry.width * wp / 100
end end
end end
end end

View File

@ -18,7 +18,6 @@ local capi = { screen = screen,
timer = timer } timer = timer }
local button = require("awful.button") local button = require("awful.button")
local util = require("awful.util") local util = require("awful.util")
local wibox = require("awful.wibox")
local bt = require("beautiful") local bt = require("beautiful")
local layout = require("awful.widget.layout") local layout = require("awful.widget.layout")
@ -120,7 +119,7 @@ end
-- @param width Popup width (optional) -- @param width Popup width (optional)
-- @return Absolute position and index in { x = X, y = Y, idx = I } table -- @return Absolute position and index in { x = X, y = Y, idx = I } table
local function get_offset(screen, position, idx, width, height) local function get_offset(screen, position, idx, width, height)
local ws = wibox.get_workarea(screen) local ws = capi.screen[screen].workarea
local v = {} local v = {}
local idx = idx or #notifications[screen][position] + 1 local idx = idx or #notifications[screen][position] + 1
local width = width or notifications[screen][position][idx].width local width = width or notifications[screen][position][idx].width
@ -368,7 +367,7 @@ function notify(args)
end end
-- crop to workarea size if too big -- crop to workarea size if too big
local workarea = wibox.get_workarea(screen) local workarea = capi.screen[screen].workarea
if width > workarea.width - 2 * (border_width or 0) - 2 * (config.padding or 0) then if width > workarea.width - 2 * (border_width or 0) - 2 * (config.padding or 0) then
width = workarea.width - 2 * (border_width or 0) - 2 * (config.padding or 0) width = workarea.width - 2 * (border_width or 0) - 2 * (config.padding or 0)
end end