Merge pull request #776 from Elv13/awful_screen_improvments
Awful screen improvements
This commit is contained in:
commit
e83832f41a
|
@ -136,27 +136,18 @@ function layout.parameters(t, screen)
|
||||||
|
|
||||||
local p = {}
|
local p = {}
|
||||||
|
|
||||||
p.workarea = screen.workarea
|
|
||||||
|
|
||||||
local useless_gap = t and tag.getgap(t, #client.tiled(screen)) or 0
|
local useless_gap = t and tag.getgap(t, #client.tiled(screen)) or 0
|
||||||
|
|
||||||
-- Handle padding
|
p.workarea = ascreen.get_bounding_geometry(screen, {
|
||||||
local padding = ascreen.padding(screen) or {}
|
honor_padding = true,
|
||||||
|
honor_workarea = true,
|
||||||
p.workarea.x = p.workarea.x + (padding.left or 0) + useless_gap
|
margins = useless_gap,
|
||||||
|
})
|
||||||
p.workarea.y = p.workarea.y + (padding.top or 0) + useless_gap
|
|
||||||
|
|
||||||
p.workarea.width = p.workarea.width - ((padding.left or 0 ) +
|
|
||||||
(padding.right or 0) + useless_gap * 2)
|
|
||||||
|
|
||||||
p.workarea.height = p.workarea.height - ((padding.top or 0) +
|
|
||||||
(padding.bottom or 0) + useless_gap * 2)
|
|
||||||
|
|
||||||
p.geometry = screen.geometry
|
p.geometry = screen.geometry
|
||||||
p.clients = client.tiled(screen)
|
p.clients = client.tiled(screen)
|
||||||
p.screen = screen.index
|
p.screen = screen.index
|
||||||
p.padding = padding
|
p.padding = ascreen.padding(screen)
|
||||||
p.useless_gap = useless_gap
|
p.useless_gap = useless_gap
|
||||||
|
|
||||||
return p
|
return p
|
||||||
|
|
|
@ -30,6 +30,19 @@ data.padding = {}
|
||||||
|
|
||||||
screen.mouse_per_screen = {}
|
screen.mouse_per_screen = {}
|
||||||
|
|
||||||
|
--- Take an input geometry and substract/add a delta
|
||||||
|
-- @tparam table geo A geometry (width, height, x, y) table
|
||||||
|
-- @tparam table delta A delata table (top, bottom, x, y)
|
||||||
|
-- @treturn table A geometry (width, height, x, y) table
|
||||||
|
local function apply_geometry_ajustments(geo, delta)
|
||||||
|
return {
|
||||||
|
x = geo.x + (delta.left or 0),
|
||||||
|
y = geo.y + (delta.top or 0),
|
||||||
|
width = geo.width - (delta.left or 0) - (delta.right or 0),
|
||||||
|
height = geo.height - (delta.top or 0) - (delta.bottom or 0),
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
-- @param s Screen
|
-- @param s Screen
|
||||||
-- @param x X coordinate of point
|
-- @param x X coordinate of point
|
||||||
-- @param y Y coordinate of point
|
-- @param y Y coordinate of point
|
||||||
|
@ -135,22 +148,99 @@ end
|
||||||
|
|
||||||
--- Get or set the screen padding.
|
--- Get or set the screen padding.
|
||||||
-- @param _screen The screen object to change the padding on
|
-- @param _screen The screen object to change the padding on
|
||||||
-- @param padding The padding, a table with 'top', 'left', 'right' and/or
|
-- @param[opt=nil] padding The padding, a table with 'top', 'left', 'right' and/or
|
||||||
-- 'bottom'. Can be nil if you only want to retrieve padding
|
-- 'bottom' or a number value to apply set the same padding on all sides. Can be
|
||||||
|
-- nil if you only want to retrieve padding
|
||||||
|
-- @treturn table A table with left, right, top and bottom number values.
|
||||||
function screen.padding(_screen, padding)
|
function screen.padding(_screen, padding)
|
||||||
|
if type(padding) == "number" then
|
||||||
|
padding = {
|
||||||
|
left = padding,
|
||||||
|
right = padding,
|
||||||
|
top = padding,
|
||||||
|
bottom = padding,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
_screen = get_screen(_screen)
|
_screen = get_screen(_screen)
|
||||||
if padding then
|
if padding then
|
||||||
data.padding[_screen] = padding
|
data.padding[_screen] = padding
|
||||||
_screen:emit_signal("padding")
|
_screen:emit_signal("padding")
|
||||||
end
|
end
|
||||||
return data.padding[_screen]
|
|
||||||
|
local p = data.padding[_screen] or {}
|
||||||
|
|
||||||
|
-- Create a copy to avoid accidental mutation and nil values
|
||||||
|
return {
|
||||||
|
left = p.left or 0,
|
||||||
|
right = p.right or 0,
|
||||||
|
top = p.top or 0,
|
||||||
|
bottom = p.bottom or 0,
|
||||||
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Get the focused screen.
|
--- Get the focused screen.
|
||||||
-- This can be replaced in a user's config.
|
--
|
||||||
-- @treturn integer
|
-- Valid arguments are:
|
||||||
function screen.focused()
|
--
|
||||||
return capi.mouse.screen
|
-- * **client**: Use the client screen instead of the mouse screen.
|
||||||
|
-- * **mouse**: Use the mouse screen (default).
|
||||||
|
--
|
||||||
|
-- It is possible to set `awful.screen.default_focused_args` to override the
|
||||||
|
-- default settings.
|
||||||
|
--
|
||||||
|
-- @tparam[opt={}] table args Some arguments.
|
||||||
|
-- @treturn screen The focused screen object
|
||||||
|
function screen.focused(args)
|
||||||
|
args = args or screen.default_focused_args or {}
|
||||||
|
return get_screen(args.client and capi.client.screen or capi.mouse.screen)
|
||||||
|
end
|
||||||
|
|
||||||
|
--- Get a placement bounding geometry.
|
||||||
|
-- This method compute different variants of the "usable" screen geometry.
|
||||||
|
--
|
||||||
|
-- Valid arguments are:
|
||||||
|
--
|
||||||
|
-- * **honor_padding**: Honor the screen padding.
|
||||||
|
-- * **honor_workarea**: Honor the screen workarea
|
||||||
|
-- * **margins**: Apply some margins on the output. This can wither be a number
|
||||||
|
-- or a table with *left*, *right*, *top* and *bottom* keys.
|
||||||
|
-- * **tag**: Use the tag screen instead of `s`
|
||||||
|
-- * **parent**: A parent drawable to use a base geometry
|
||||||
|
-- * **bounding_rect**: A bounding rectangle. This parameter is incompatible with
|
||||||
|
-- `honor_workarea`.
|
||||||
|
--
|
||||||
|
-- @tparam[opt=mouse.screen] screen s A screen
|
||||||
|
-- @tparam[opt={}] table args The arguments
|
||||||
|
-- @treturn table A table with *x*, *y*, *width* and *height*.
|
||||||
|
function screen.get_bounding_geometry(s, args)
|
||||||
|
args = args or {}
|
||||||
|
|
||||||
|
-- If the tag has a geometry, assume it is right
|
||||||
|
if args.tag then
|
||||||
|
s = args.tag.screen
|
||||||
|
end
|
||||||
|
|
||||||
|
s = get_screen(s or capi.mouse.screen)
|
||||||
|
|
||||||
|
local geo = args.bounding_rect or (args.parent and args.parent:geometry()) or
|
||||||
|
s[args.honor_workarea and "workarea" or "geometry"]
|
||||||
|
|
||||||
|
if (not args.parent) and (not args.bounding_rect) and args.honor_padding then
|
||||||
|
local padding = screen.padding(s)
|
||||||
|
geo = apply_geometry_ajustments(geo, padding)
|
||||||
|
end
|
||||||
|
|
||||||
|
if args.margins then
|
||||||
|
geo = apply_geometry_ajustments(geo,
|
||||||
|
type(args.margins) == "table" and args.margins or {
|
||||||
|
left = args.margins, right = args.margins,
|
||||||
|
top = args.margins, bottom = args.margins,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
return geo
|
||||||
end
|
end
|
||||||
|
|
||||||
capi.screen.add_signal("padding")
|
capi.screen.add_signal("padding")
|
||||||
|
|
Loading…
Reference in New Issue