mirror of
				https://codeberg.org/dwl/dwl-patches.git
				synced 2025-10-26 09:44:21 +00:00 
			
		
		
		
	update relative-mouse-resize for HEAD
This commit is contained in:
		
							parent
							
								
									b828e21717
								
							
						
					
					
						commit
						655fd2916c
					
				| @ -1,20 +1,20 @@ | ||||
| From cd7dec8ff61fef268a5c5053d33eb202b09ea3f6 Mon Sep 17 00:00:00 2001 | ||||
| From 67e4ca7a35e38c6874aa614a04da4c1b04577c19 Mon Sep 17 00:00:00 2001 | ||||
| From: wochap <gean.marroquin@gmail.com> | ||||
| Date: Wed, 6 Mar 2024 09:51:29 -0500 | ||||
| Subject: [PATCH] implement relative mouse resize | ||||
| Date: Thu, 11 Apr 2024 14:17:30 -0500 | ||||
| Subject: [PATCH] mouse resize the window in the quadrant that the resize | ||||
|  starts at | ||||
| 
 | ||||
| the mouse willresize the window in the quadrant that the resize starts at | ||||
| inspiration: https://github.com/djpohly/dwl/wiki/relativemouseresize | ||||
| ---
 | ||||
|  dwl.c | 66 ++++++++++++++++++++++++++++++++++++++++++++++++++++------- | ||||
|  1 file changed, 59 insertions(+), 7 deletions(-) | ||||
| 
 | ||||
| diff --git a/dwl.c b/dwl.c
 | ||||
| index ef27a1d..deb8c76 100644
 | ||||
| index bf763df..f78ac34 100644
 | ||||
| --- a/dwl.c
 | ||||
| +++ b/dwl.c
 | ||||
| @@ -370,7 +370,8 @@ static struct wlr_seat *seat;
 | ||||
|  static struct wl_list keyboards; | ||||
| @@ -398,7 +398,8 @@ static KeyboardGroup vkb_group = {0};
 | ||||
|  static struct wlr_surface *held_grab; | ||||
|  static unsigned int cursor_mode; | ||||
|  static Client *grabc; | ||||
| -static int grabcx, grabcy; /* client-relative */
 | ||||
| @ -23,37 +23,37 @@ index ef27a1d..deb8c76 100644 | ||||
|   | ||||
|  static struct wlr_output_layout *output_layout; | ||||
|  static struct wlr_box sgeom; | ||||
| @@ -1645,8 +1646,27 @@ motionnotify(uint32_t time)
 | ||||
| @@ -1737,8 +1738,27 @@ motionnotify(uint32_t time, struct wlr_input_device *device, double dx, double d
 | ||||
|  			.width = grabc->geom.width, .height = grabc->geom.height}, 1); | ||||
|  		return; | ||||
|  	} else if (cursor_mode == CurResize) { | ||||
| -		resize(grabc, (struct wlr_box){.x = grabc->geom.x, .y = grabc->geom.y,
 | ||||
| -			.width = cursor->x - grabc->geom.x, .height = cursor->y - grabc->geom.y}, 1);
 | ||||
| -			.width = ROUND(cursor->x) - grabc->geom.x, .height = ROUND(cursor->y) - grabc->geom.y}, 1);
 | ||||
| +		if (grabcenterx < grabx) {
 | ||||
| +			if (grabcentery < graby) {
 | ||||
| +				/* bottom-right */
 | ||||
| +				resize(grabc, (struct wlr_box){.x = initial_grabc.geom.x, .y = initial_grabc.geom.y,
 | ||||
| +					.width = cursor->x - initial_grabc.geom.x, .height = cursor->y - initial_grabc.geom.y}, 1);
 | ||||
| +					.width = ROUND(cursor->x) - initial_grabc.geom.x, .height = ROUND(cursor->y) - initial_grabc.geom.y}, 1);
 | ||||
| +			} else {
 | ||||
| +				/* top-right */
 | ||||
| +				resize(grabc, (struct wlr_box){.x = initial_grabc.geom.x, .y = cursor->y,
 | ||||
| +					.width = cursor->x - initial_grabc.geom.x, .height = initial_grabc.geom.y + initial_grabc.geom.height - cursor->y}, 1);
 | ||||
| +				resize(grabc, (struct wlr_box){.x = initial_grabc.geom.x, .y = ROUND(cursor->y),
 | ||||
| +					.width = ROUND(cursor->x) - initial_grabc.geom.x, .height = initial_grabc.geom.y + initial_grabc.geom.height - ROUND(cursor->y)}, 1);
 | ||||
| +			}
 | ||||
| +		} else {
 | ||||
| +			if (grabcentery < graby) {
 | ||||
| +				/* bottom-left */
 | ||||
| +				resize(grabc, (struct wlr_box){.x = cursor->x, .y = initial_grabc.geom.y,
 | ||||
| +					.width = initial_grabc.geom.x + initial_grabc.geom.width - cursor->x, .height = cursor->y - initial_grabc.geom.y}, 1);
 | ||||
| +				resize(grabc, (struct wlr_box){.x = ROUND(cursor->x), .y = initial_grabc.geom.y,
 | ||||
| +					.width = initial_grabc.geom.x + initial_grabc.geom.width - ROUND(cursor->x), .height = ROUND(cursor->y) - initial_grabc.geom.y}, 1);
 | ||||
| +			} else {
 | ||||
| +				/* top-left */
 | ||||
| +				resize(grabc, (struct wlr_box){.x = cursor->x, .y = cursor->y,
 | ||||
| +					.width = initial_grabc.geom.x + initial_grabc.geom.width - cursor->x, .height = initial_grabc.geom.y + initial_grabc.geom.height - cursor->y}, 1);
 | ||||
| +				resize(grabc, (struct wlr_box){.x = ROUND(cursor->x), .y = ROUND(cursor->y),
 | ||||
| +					.width = initial_grabc.geom.x + initial_grabc.geom.width - ROUND(cursor->x), .height = initial_grabc.geom.y + initial_grabc.geom.height - ROUND(cursor->y)}, 1);
 | ||||
| +			}
 | ||||
| +		}
 | ||||
|  		return; | ||||
|  	} | ||||
|   | ||||
| @@ -1707,10 +1727,42 @@ moveresize(const Arg *arg)
 | ||||
| @@ -1797,10 +1817,42 @@ moveresize(const Arg *arg)
 | ||||
|  	case CurResize: | ||||
|  		/* Doesn't work for X11 output - the next absolute motion event | ||||
|  		 * returns the cursor to where it started */ | ||||
| @ -62,10 +62,10 @@ index ef27a1d..deb8c76 100644 | ||||
| -				grabc->geom.y + grabc->geom.height);
 | ||||
| -		wlr_cursor_set_xcursor(cursor, cursor_mgr, "se-resize");
 | ||||
| +		initial_grabc = *grabc;
 | ||||
| +		grabx = cursor->x;
 | ||||
| +		graby = cursor->y;
 | ||||
| +		grabcx = cursor->x - grabc->geom.x;
 | ||||
| +		grabcy = cursor->y - grabc->geom.y;
 | ||||
| +		grabx = ROUND(cursor->x);
 | ||||
| +		graby = ROUND(cursor->y);
 | ||||
| +		grabcx = ROUND(cursor->x) - grabc->geom.x;
 | ||||
| +		grabcy = ROUND(cursor->y) - grabc->geom.y;
 | ||||
| +		grabcenterx = grabc->geom.width / 2 + grabc->geom.x;
 | ||||
| +		grabcentery = grabc->geom.height / 2 + grabc->geom.y;
 | ||||
| +		if (grabcenterx < grabx) {
 | ||||
| @ -101,6 +101,5 @@ index ef27a1d..deb8c76 100644 | ||||
|  	} | ||||
|  } | ||||
| -- 
 | ||||
| 2.42.0 | ||||
| 
 | ||||
| 2.43.2 | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 wochap
						wochap