Add screenshots for the 'max' layout indicator

This commit is contained in:
Emmanuel Lepage Vallee 2014-10-02 23:57:22 -04:00
parent 21b412ece2
commit b843d3b2a7
3 changed files with 68 additions and 13 deletions

View File

@ -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

View File

@ -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
View File

@ -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