resistance: move strength.c to resistance.c

This commit is contained in:
ARDiDo 2021-10-24 12:13:20 -04:00 committed by Johan Malm
parent 8f8359597c
commit ef78d40cb7

123
src/resistance.c Normal file
View file

@ -0,0 +1,123 @@
#include "labwc.h"
#include "config/rcxml.h"
/* These functions could be extended to strength in the future. */
void
move_resistance(struct view *view, double *x, double *y, bool screen_edge)
{
struct server *server = view->server;
struct wlr_box mgeom;
struct output *output;
struct border border = view_border(view);
int l, r, t, b; /* The edges of the current view */
int tl, tr, tt, tb; /* The desired edges */
int ml, mr, mt, mb; /* The edges of the monitor/other view */
l = view->x - border.left - rc.gap;
t = view->y - border.top - rc.gap;
r = view->x + view->w + border.right + rc.gap;
b = view->y + view->h + border.bottom + rc.gap;
tl = *x - border.left - rc.gap;
tt = *y - border.top - rc.gap;
tr = *x + view->w + border.right + rc.gap;
tb = *y + view->h + border.bottom + rc.gap;
if (screen_edge) {
if (!rc.screen_edge_strength) {
return;
}
wl_list_for_each(output, &server->outputs, link) {
mgeom = output_usable_area_in_layout_coords(output);
ml = mgeom.x;
mt = mgeom.y;
mr = mgeom.x + mgeom.width;
mb = mgeom.y + mgeom.height;
if (l >= ml && tl < ml && tl >= ml
- rc.screen_edge_strength) {
*x = ml + border.left + rc.gap;
} else if (r <= mr && tr > mr && tr <= mr
+ rc.screen_edge_strength) {
*x = mr - view->w - border.right - rc.gap;
}
if (t >= mt && tt < mt && tt >= mt
- rc.screen_edge_strength) {
*y = mt + border.top + rc.gap;
} else if (b <= mb && tb > mb && tb <= mb
+ rc.screen_edge_strength) {
*y = mb - view->h - border.bottom - rc.gap;
}
}
}
}
void
resize_resistance(struct view *view, struct wlr_box *new_view_geo,
bool screen_edge)
{
struct server *server = view->server;
struct output *output;
struct wlr_box mgeom;
struct border border = view_border(view);
int l, r, t, b; /* The edges of the current view */
int tl, tr, tt, tb; /* The desired edges */
int ml, mr, mt, mb; /* The edges of the monitor/other view */
l = view->x - border.left - rc.gap;
t = view->y - border.top - rc.gap;
r = view->x + view->w + border.right + rc.gap;
b = view->y + view->h + border.bottom + rc.gap;
tl = new_view_geo->x - border.left - rc.gap;
tt = new_view_geo->y - border.top - rc.gap;
tr = new_view_geo->x + new_view_geo->width + border.right + rc.gap;
tb = new_view_geo->y + new_view_geo->height + border.bottom + rc.gap;
if (screen_edge) {
if (!rc.screen_edge_strength) {
return;
}
wl_list_for_each(output, &server->outputs, link) {
mgeom = output_usable_area_in_layout_coords(output);
ml = mgeom.x;
mt = mgeom.y;
mr = mgeom.x + mgeom.width;
mb = mgeom.y + mgeom.height;
if (server->resize_edges & WLR_EDGE_LEFT) {
if (l >= ml && tl < ml && tl >= ml
- rc.screen_edge_strength) {
new_view_geo->x = ml + border.left
+ rc.gap;
new_view_geo->width = view->w;
}
} else if (server->resize_edges & WLR_EDGE_RIGHT) {
if (r <= mr && tr > mr && tr <= mr
+ rc.screen_edge_strength) {
new_view_geo->width = mr - l
- (border.right + rc.gap) * 2 ;
}
}
if (server->resize_edges & WLR_EDGE_TOP) {
if (t >= mt && tt < mt && tt >= mt
- rc.screen_edge_strength) {
new_view_geo->y = mt + border.top
+ rc.gap;
new_view_geo->height = view->h;
}
} else if (server->resize_edges & WLR_EDGE_BOTTOM) {
if (b <= mb && tb > mb && tb <= mb
+ rc.screen_edge_strength) {
new_view_geo->height = mb - t
- border.bottom - border.top
- rc.gap * 2;
}
}
}
}
}