]> git.sur5r.net Git - i3/i3/blobdiff - include/resize.h
Make cmd_resize_tiling_direction work with pixels
[i3/i3] / include / resize.h
index 520d4398431c5624286a5ff6ded67bb23b5a5f17..758cb4a1a28376f5e4bdd4d9d8c1ccc305fc5742 100644 (file)
@@ -1,27 +1,32 @@
 /*
- * vim:ts=8:expandtab
+ * vim:ts=4:sw=4:expandtab
  *
  * i3 - an improved dynamic tiling window manager
+ * © 2009 Michael Stapelberg and contributors (see also: LICENSE)
  *
- * (c) 2009 Michael Stapelberg and contributors
- *
- * See file LICENSE for license information.
+ * resize.c: Interactive resizing.
  *
  */
+#pragma once
 
-#ifndef _RESIZE_H
-#define _RESIZE_H
+#include <config.h>
 
-#include <xcb/xcb.h>
+bool resize_find_tiling_participants(Con **current, Con **other, direction_t direction, bool both_sides);
 
-typedef enum { O_HORIZONTAL, O_VERTICAL } resize_orientation_t;
+void resize_graphical_handler(Con *first, Con *second, orientation_t orientation, const xcb_button_press_event_t *event);
 
 /**
- * Renders the resize window between the first/second container and resizes
- * the table column/row.
+ * Resize the two given containers using the given amount of pixels or
+ * percentage points. One of the two needs to be 0. A positive amount means
+ * growing the first container while a negative means shrinking it.
+ * Returns false when the resize would result in one of the two containers
+ * having less than 1 pixel of size.
  *
  */
-int resize_graphical_handler(xcb_connection_t *conn, Workspace *ws, int first, int second,
-                             resize_orientation_t orientation, xcb_button_press_event_t *event);
+bool resize_neighboring_cons(Con *first, Con *second, int px, int ppt);
 
-#endif
+/**
+ * Calculate the given container's new percent given a change in pixels.
+ *
+ */
+double px_resize_to_percent(Con *con, int px_diff);