Add screenshots for the 'max' layout indicator
This commit is contained in:
parent
21b412ece2
commit
b843d3b2a7
|
@ -57,7 +57,7 @@ while the `Control` key is used to max out the effect.
|
||||||
| `Mod4` | `Shift` | `Control` | Move a floating client to the far side of that screen |
|
| `Mod4` | `Shift` | `Control` | Move a floating client to the far side of that screen |
|
||||||
| `Mod4` | `Mod1 (Alt)` | | Resize a client relative to the bottom right corner |
|
| `Mod4` | `Mod1 (Alt)` | | Resize a client relative to the bottom right corner |
|
||||||
| `Mod4` | `Mod1 (Alt)` | `Shift` | Resize a client relative to the top left corner |
|
| `Mod4` | `Mod1 (Alt)` | `Shift` | Resize a client relative to the top left corner |
|
||||||
| `Control` | `Mod1 (Alt)` | | Move to the next/previous tag
|
| `Control` | `Mod1 (Alt)` | | Move to the next/previous tag |
|
||||||
|
|
||||||
# Using different keys
|
# Using different keys
|
||||||
|
|
||||||
|
|
2
init.lua
2
init.lua
|
@ -81,7 +81,7 @@ local function start_loop(is_swap,is_max)
|
||||||
end
|
end
|
||||||
|
|
||||||
function module.focus(direction,c,max)
|
function module.focus(direction,c,max)
|
||||||
local screen = (c and c.screen) or (capi.client.focus and capi.client.focus.screen) or capi.mouse.screen
|
local screen = (c or ((capi.client.focus and capi.client.focus.focusable) and capi.client.focus or capi.mouse)).screen
|
||||||
-- Useless when there is only 1 client tiled, incompatible with the "max_out" mode (in this case, focus floating mode)
|
-- Useless when there is only 1 client tiled, incompatible with the "max_out" mode (in this case, focus floating mode)
|
||||||
if awful.layout.get(screen) == awful.layout.suit.max and #awful.client.tiled(screen) > 1 and not max then
|
if awful.layout.get(screen) == awful.layout.suit.max and #awful.client.tiled(screen) > 1 and not max then
|
||||||
current_mode = "max"
|
current_mode = "max"
|
||||||
|
|
77
max.lua
77
max.lua
|
@ -124,15 +124,11 @@ local function draw_shape(s,collection,current_idx,icon_f,y)
|
||||||
cr3:paint()
|
cr3:paint()
|
||||||
|
|
||||||
-- Print the icon
|
-- Print the icon
|
||||||
local icon = icon_f(v)
|
local icon = icon_f(v,width-20,height-20-50)
|
||||||
if icon then
|
if icon then
|
||||||
cr3:save()
|
cr3:save()
|
||||||
local w,h = icon:get_width(),icon:get_height()
|
cr3:translate(dx+10,10)
|
||||||
local aspect,aspect_h = width / w,(height-50) / h
|
cr3:set_source_surface(icon)
|
||||||
if aspect > aspect_h then aspect = aspect_h end
|
|
||||||
cr3:translate(dx+width/2,(height-50)/2)
|
|
||||||
cr3:scale(aspect, aspect)
|
|
||||||
cr3:set_source_surface(icon,-w/2,-h/2)
|
|
||||||
cr3:paint_with_alpha(0.7)
|
cr3:paint_with_alpha(0.7)
|
||||||
cr3:restore()
|
cr3:restore()
|
||||||
end
|
end
|
||||||
|
@ -172,8 +168,56 @@ function module.hide()
|
||||||
end
|
end
|
||||||
|
|
||||||
--Client related
|
--Client related
|
||||||
local function client_icon(c)
|
local function client_icon(c,width,height)
|
||||||
return surface(c.icon)
|
-- Get the content
|
||||||
|
--TODO detect pure black frames
|
||||||
|
local img = cairo.ImageSurface(cairo.Format.ARGB32, width, height)
|
||||||
|
local cr = cairo.Context(img)
|
||||||
|
|
||||||
|
local geom = c:geometry()
|
||||||
|
local scale = width/geom.width
|
||||||
|
if geom.height*scale > height then
|
||||||
|
scale = height/geom.height
|
||||||
|
end
|
||||||
|
local w,h = geom.width*scale,geom.height*scale
|
||||||
|
|
||||||
|
-- Create a mask
|
||||||
|
cr:save()
|
||||||
|
cr:translate((width-w)/2,(height-h)/2)
|
||||||
|
cr:arc(10,10,10,0,math.pi*2)
|
||||||
|
cr:fill()
|
||||||
|
cr:arc(w-10,10,10,0,math.pi*2)
|
||||||
|
cr:fill()
|
||||||
|
cr:arc(w-10,h-10,10,0,math.pi*2)
|
||||||
|
cr:fill()
|
||||||
|
cr:arc(10,h-10,10,0,math.pi*2)
|
||||||
|
cr:fill()
|
||||||
|
cr:rectangle(10,0,w-20,h)
|
||||||
|
cr:rectangle(0,10,w,h-20)
|
||||||
|
cr:fill()
|
||||||
|
|
||||||
|
-- Create a matrix to scale down the screenshot
|
||||||
|
cr:save()
|
||||||
|
cr:scale(scale,scale)
|
||||||
|
|
||||||
|
-- Paint the screenshot in the rounded rectangle
|
||||||
|
cr:set_source_surface(surface(c.content))
|
||||||
|
cr:set_operator(cairo.Operator.IN)
|
||||||
|
cr:paint()
|
||||||
|
cr:restore()
|
||||||
|
cr:restore()
|
||||||
|
|
||||||
|
-- Add icon on top, "solve" the black window issue
|
||||||
|
local icon = surface(c.icon)
|
||||||
|
local w,h = icon:get_width(),icon:get_height()
|
||||||
|
local aspect,aspect_h = width / w,(height) / h
|
||||||
|
if aspect > aspect_h then aspect = aspect_h end
|
||||||
|
cr:translate((width-w*aspect)/2,(height-h*aspect)/2)
|
||||||
|
cr:scale(aspect, aspect)
|
||||||
|
cr:set_source_surface(icon)
|
||||||
|
cr:paint_with_alpha(0.5)
|
||||||
|
|
||||||
|
return img
|
||||||
end
|
end
|
||||||
|
|
||||||
function module.display_clients(s,direction)
|
function module.display_clients(s,direction)
|
||||||
|
@ -201,8 +245,19 @@ function module.change_focus(mod,key,event,direction,is_swap,is_max)
|
||||||
end
|
end
|
||||||
|
|
||||||
--Tag related
|
--Tag related
|
||||||
local function tag_icon(t)
|
local function tag_icon(t,width,height)
|
||||||
return surface(awful.tag.geticon(t))
|
local img = cairo.ImageSurface(cairo.Format.ARGB32, width, height)
|
||||||
|
local cr = cairo.Context(img)
|
||||||
|
|
||||||
|
local icon = surface(awful.tag.geticon(t))
|
||||||
|
local w,h = icon:get_width(),icon:get_height()
|
||||||
|
local aspect,aspect_h = width / w,(height) / h
|
||||||
|
if aspect > aspect_h then aspect = aspect_h end
|
||||||
|
cr:translate((width-w*aspect)/2,(height-h*aspect)/2)
|
||||||
|
cr:scale(aspect, aspect)
|
||||||
|
cr:set_source_surface(icon)
|
||||||
|
cr:paint()
|
||||||
|
return img
|
||||||
end
|
end
|
||||||
|
|
||||||
local tmp_screen = nil
|
local tmp_screen = nil
|
||||||
|
|
Loading…
Reference in New Issue