mirror of
https://github.com/labwc/labwc.git
synced 2026-02-25 01:40:28 -05:00
feat: add Shade/Unshade/ToggleShade actions
This builds on the work of @Consolatis in #1018. Co-authored-by: Consolatis <35009135+Consolatis@users.noreply.github.com> Co-authored-by: Andrew J. Hesford <ajh@sideband.org>
This commit is contained in:
parent
722a802de0
commit
e05bedb140
19 changed files with 218 additions and 47 deletions
|
|
@ -47,15 +47,18 @@ resistance_move_apply(struct view *view, double *x, double *y)
|
|||
struct edges other_edges; /* The edges of the monitor/other view */
|
||||
struct edges flags = { 0 };
|
||||
|
||||
/* Use the effective height to properly snap shaded views */
|
||||
int eff_height = view_effective_height(view, /* use_pending */ false);
|
||||
|
||||
view_edges.left = vgeom.x - border.left + 1;
|
||||
view_edges.top = vgeom.y - border.top + 1;
|
||||
view_edges.right = vgeom.x + vgeom.width + border.right;
|
||||
view_edges.bottom = vgeom.y + vgeom.height + border.bottom;
|
||||
view_edges.bottom = vgeom.y + eff_height + border.bottom;
|
||||
|
||||
target_edges.left = *x - border.left;
|
||||
target_edges.top = *y - border.top;
|
||||
target_edges.right = *x + vgeom.width + border.right;
|
||||
target_edges.bottom = *y + vgeom.height + border.bottom;
|
||||
target_edges.bottom = *y + eff_height + border.bottom;
|
||||
|
||||
if (!rc.screen_edge_strength) {
|
||||
return;
|
||||
|
|
@ -91,7 +94,7 @@ resistance_move_apply(struct view *view, double *x, double *y)
|
|||
if (flags.top == 1) {
|
||||
*y = other_edges.top + border.top;
|
||||
} else if (flags.bottom == 1) {
|
||||
*y = other_edges.bottom - vgeom.height - border.bottom;
|
||||
*y = other_edges.bottom - eff_height - border.bottom;
|
||||
}
|
||||
|
||||
/* reset the flags */
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue