mouse.snap: Use a composed placement function

This commit is contained in:
Emmanuel Lepage Vallee 2016-04-23 20:08:42 -04:00
parent 1802e9e2fe
commit 07e1b975a7
1 changed files with 26 additions and 10 deletions

View File

@ -71,6 +71,14 @@ local function show_placeholder(geo)
placeholder_w.visible = true placeholder_w.visible = true
end end
local function build_placement(snap, axis)
return aplace.scale
+ aplace[snap]
+ (
axis and aplace["maximize_"..axis] or nil
)
end
local function detect_screen_edges(c, snap) local function detect_screen_edges(c, snap)
local coords = capi.mouse.coords() local coords = capi.mouse.coords()
@ -93,7 +101,7 @@ local function detect_screen_edges(c, snap)
return v, h return v, h
end end
local current_snap = nil local current_snap, current_axis = nil
local function detect_areasnap(c, distance) local function detect_areasnap(c, distance)
local old_snap = current_snap local old_snap = current_snap
@ -105,15 +113,20 @@ local function detect_areasnap(c, distance)
current_snap = v or h or nil current_snap = v or h or nil
end end
if old_snap == current_snap then return end
current_axis = ((v and not h) and "horizontally")
or ((h and not v) and "vertically")
or nil
-- Show the expected geometry outline -- Show the expected geometry outline
if current_snap ~= old_snap then show_placeholder(
show_placeholder( current_snap and build_placement(current_snap, current_axis)(c, {
current_snap and aplace[current_snap](c, { to_percent = 0.5,
honor_workarea = true, honor_workarea = true,
pretend = true pretend = true
}) or nil }) or nil
) )
end
end end
@ -125,7 +138,10 @@ local function apply_areasnap(c, args)
placeholder_w.visible = false placeholder_w.visible = false
return aplace[current_snap](c,{honor_workarea=true}) return build_placement(current_snap, current_axis)(c,{
to_percent = 0.5,
honor_workarea = true,
})
end end
local function snap_outside(g, sg, snap) local function snap_outside(g, sg, snap)