mirror of
https://github.com/wizbright/waybox.git
synced 2025-10-29 05:40:20 -04:00
Allow maximizing; ToggleMaximize action
This commit is contained in:
parent
c4e224d5fa
commit
afe1780ec3
8 changed files with 84 additions and 39 deletions
|
|
@ -27,6 +27,9 @@
|
||||||
<execute>grim "$(xdg-user-dir PICTURES)/$(date +'%Y-%m-%d-%H%M%S_grim_fs.png')"</execute>
|
<execute>grim "$(xdg-user-dir PICTURES)/$(date +'%Y-%m-%d-%H%M%S_grim_fs.png')"</execute>
|
||||||
</action>
|
</action>
|
||||||
</keybind>
|
</keybind>
|
||||||
|
<keybind key="W-S-M">
|
||||||
|
<action name="ToggleMaximize"/>
|
||||||
|
</keybind>
|
||||||
<!-- Keybindings for window switching -->
|
<!-- Keybindings for window switching -->
|
||||||
<keybind key="A-Tab">
|
<keybind key="A-Tab">
|
||||||
<action name="NextWindow">
|
<action name="NextWindow">
|
||||||
|
|
|
||||||
|
|
@ -80,12 +80,14 @@ then
|
||||||
WB_RC_XML=$WB_SYS_CONF_DIR/rc.xml
|
WB_RC_XML=$WB_SYS_CONF_DIR/rc.xml
|
||||||
elif test -f $OB_USER_CONF_DIR/rc.xml;
|
elif test -f $OB_USER_CONF_DIR/rc.xml;
|
||||||
then
|
then
|
||||||
|
_ "WARNING: Using files from Openbox. These may not work correctly."
|
||||||
WB_RC_XML=$OB_USER_CONF_DIR/rc.xml
|
WB_RC_XML=$OB_USER_CONF_DIR/rc.xml
|
||||||
elif test -f $OB_SYS_CONF_DIR/rc.xml;
|
elif test -f $OB_SYS_CONF_DIR/rc.xml;
|
||||||
then
|
then
|
||||||
|
_ "WARNING: Using files from Openbox. These may not work correctly."
|
||||||
WB_RC_XML=$OB_SYS_CONF_DIR/rc.xml;
|
WB_RC_XML=$OB_SYS_CONF_DIR/rc.xml;
|
||||||
else
|
else
|
||||||
_ "ERROR: No configuration file found."
|
_ "ERROR: No configuration file found." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
export WB_RC_XML
|
export WB_RC_XML
|
||||||
|
|
|
||||||
|
|
@ -28,7 +28,7 @@ do
|
||||||
elif cat "$f" | grep -q "^Hidden\s*=\s*true$";
|
elif cat "$f" | grep -q "^Hidden\s*=\s*true$";
|
||||||
then
|
then
|
||||||
show_in=0
|
show_in=0
|
||||||
# Value of WAYBOX: run all programs
|
# Value of all: run all programs
|
||||||
elif test "$WB_AUTOSTART_ENVIRONMENT" = "all";
|
elif test "$WB_AUTOSTART_ENVIRONMENT" = "all";
|
||||||
then
|
then
|
||||||
show_in=1
|
show_in=1
|
||||||
|
|
|
||||||
|
|
@ -32,14 +32,16 @@ struct wb_view {
|
||||||
|
|
||||||
struct wlr_xdg_toplevel_decoration_v1 *decoration;
|
struct wlr_xdg_toplevel_decoration_v1 *decoration;
|
||||||
|
|
||||||
struct wl_listener ack_configure;
|
|
||||||
struct wl_listener map;
|
struct wl_listener map;
|
||||||
struct wl_listener unmap;
|
struct wl_listener unmap;
|
||||||
struct wl_listener destroy;
|
struct wl_listener destroy;
|
||||||
|
struct wl_listener request_maximize;
|
||||||
struct wl_listener request_move;
|
struct wl_listener request_move;
|
||||||
struct wl_listener request_resize;
|
struct wl_listener request_resize;
|
||||||
bool configured, mapped;
|
struct wl_listener surface_commit;
|
||||||
|
bool mapped;
|
||||||
int x, y;
|
int x, y;
|
||||||
|
struct wlr_box origdim;
|
||||||
};
|
};
|
||||||
|
|
||||||
void output_frame_notify(struct wl_listener* listener, void *data);
|
void output_frame_notify(struct wl_listener* listener, void *data);
|
||||||
|
|
|
||||||
|
|
@ -72,9 +72,8 @@ static bool parse_key_bindings(struct wb_config *config, xmlXPathContextPtr ctxt
|
||||||
modifiers |= WLR_MODIFIER_SHIFT;
|
modifiers |= WLR_MODIFIER_SHIFT;
|
||||||
else if (strcmp(s, "W") == 0 || strcmp(s, "Logo") == 0)
|
else if (strcmp(s, "W") == 0 || strcmp(s, "Logo") == 0)
|
||||||
modifiers |= WLR_MODIFIER_LOGO;
|
modifiers |= WLR_MODIFIER_LOGO;
|
||||||
else
|
|
||||||
key_bind->sym = xkb_keysym_from_name(s, 0);
|
|
||||||
key_bind->modifiers = modifiers;
|
key_bind->modifiers = modifiers;
|
||||||
|
key_bind->sym = xkb_keysym_from_name(s, 0);
|
||||||
sym = NULL;
|
sym = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -100,6 +99,8 @@ static bool parse_key_bindings(struct wb_config *config, xmlXPathContextPtr ctxt
|
||||||
key_bind->action = ACTION_PREVIOUS_WINDOW;
|
key_bind->action = ACTION_PREVIOUS_WINDOW;
|
||||||
else if (strcmp(action, "Close") == 0)
|
else if (strcmp(action, "Close") == 0)
|
||||||
key_bind->action = ACTION_CLOSE;
|
key_bind->action = ACTION_CLOSE;
|
||||||
|
else if (strcmp(action, "ToggleMaximize") == 0)
|
||||||
|
key_bind->action = ACTION_TOGGLE_MAXIMIZE;
|
||||||
else if (strcmp(action, "Exit") == 0)
|
else if (strcmp(action, "Exit") == 0)
|
||||||
key_bind->action = ACTION_EXIT;
|
key_bind->action = ACTION_EXIT;
|
||||||
else if (strcmp(action, "Reconfigure") == 0)
|
else if (strcmp(action, "Reconfigure") == 0)
|
||||||
|
|
|
||||||
|
|
@ -10,7 +10,8 @@ enum action_type {
|
||||||
ACTION_EXIT,
|
ACTION_EXIT,
|
||||||
ACTION_NEXT_WINDOW,
|
ACTION_NEXT_WINDOW,
|
||||||
ACTION_PREVIOUS_WINDOW,
|
ACTION_PREVIOUS_WINDOW,
|
||||||
ACTION_RECONFIGURE
|
ACTION_RECONFIGURE,
|
||||||
|
ACTION_TOGGLE_MAXIMIZE,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct wb_config {
|
struct wb_config {
|
||||||
|
|
|
||||||
|
|
@ -88,6 +88,13 @@ static bool handle_keybinding(struct wb_server *server, xkb_keysym_t sym, uint32
|
||||||
execl("/bin/sh", "/bin/sh", "-c", key_binding->cmd, (char *) NULL);
|
execl("/bin/sh", "/bin/sh", "-c", key_binding->cmd, (char *) NULL);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
case ACTION_TOGGLE_MAXIMIZE:
|
||||||
|
{
|
||||||
|
struct wb_view *view = wl_container_of(server->views.next, view, link);
|
||||||
|
if (wlr_surface_is_xdg_surface(view->xdg_toplevel->base->surface))
|
||||||
|
wl_signal_emit(&view->xdg_toplevel->events.request_maximize, view->xdg_toplevel->base);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
case ACTION_RECONFIGURE:
|
case ACTION_RECONFIGURE:
|
||||||
deinit_config(server->config);
|
deinit_config(server->config);
|
||||||
init_config(server);
|
init_config(server);
|
||||||
|
|
|
||||||
|
|
@ -49,39 +49,29 @@ void focus_view(struct wb_view *view, struct wlr_surface *surface) {
|
||||||
keyboard->keycodes, keyboard->num_keycodes, &keyboard->modifiers);
|
keyboard->keycodes, keyboard->num_keycodes, &keyboard->modifiers);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xdg_surface_ack_configure(struct wl_listener *listener, void *data) {
|
static void xdg_surface_commit(struct wl_listener *listener, void *data) {
|
||||||
/* Called after the surface is configured */
|
/* Called after the surface is committed */
|
||||||
struct wb_view *view = wl_container_of(listener, view, ack_configure);
|
struct wb_view *view = wl_container_of(listener, view, surface_commit);
|
||||||
|
struct wlr_xdg_surface *xdg_surface = view->xdg_toplevel->base;
|
||||||
/* If there's no decoration, there's no need to change the size and
|
struct wlr_box geo_box = {0};
|
||||||
* cause endless reconfigures. */
|
wlr_xdg_surface_get_geometry(xdg_surface, &geo_box);
|
||||||
if (!view->decoration)
|
if (geo_box.x < 0 && view->x < 1)
|
||||||
return;
|
view->x += -geo_box.x;
|
||||||
|
if (geo_box.y < 0 && view->y < 1)
|
||||||
if (!view->configured)
|
view->y += -geo_box.y;
|
||||||
{
|
|
||||||
/* With client-side decorations, after setting the size, it'll
|
|
||||||
* return a negative y value, which can be used to determine the
|
|
||||||
* size of the CSD titlebar. */
|
|
||||||
struct wlr_box geo_box;
|
|
||||||
wlr_xdg_surface_get_geometry(view->xdg_toplevel->base, &geo_box);
|
|
||||||
if (geo_box.y < 0)
|
|
||||||
view->y = geo_box.y * -1;
|
|
||||||
view->configured = view->y > 0;
|
|
||||||
|
|
||||||
/* Set size here, so the view->y value will be known */
|
|
||||||
#if WLR_CHECK_VERSION(0, 16, 0)
|
|
||||||
wlr_xdg_toplevel_set_size(view->xdg_toplevel, geo_box.width - view->x, geo_box.height - view->y);
|
|
||||||
#else
|
|
||||||
wlr_xdg_toplevel_set_size(view->xdg_surface, geo_box.width - view->x, geo_box.height - view->y);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xdg_surface_map(struct wl_listener *listener, void *data) {
|
static void xdg_surface_map(struct wl_listener *listener, void *data) {
|
||||||
/* Called when the surface is mapped, or ready to display on-screen. */
|
/* Called when the surface is mapped, or ready to display on-screen. */
|
||||||
struct wb_view *view = wl_container_of(listener, view, map);
|
struct wb_view *view = wl_container_of(listener, view, map);
|
||||||
view->mapped = true;
|
view->mapped = true;
|
||||||
|
struct wlr_box geo_box = {0};
|
||||||
|
wlr_xdg_surface_get_geometry(view->xdg_toplevel->base, &geo_box);
|
||||||
|
#if WLR_CHECK_VERSION(0, 16, 0)
|
||||||
|
wlr_xdg_toplevel_set_size(view->xdg_toplevel, geo_box.width, geo_box.height);
|
||||||
|
#else
|
||||||
|
wlr_xdg_toplevel_set_size(view->xdg_surface, geo_box.width, geo_box.height);
|
||||||
|
#endif
|
||||||
focus_view(view, view->xdg_toplevel->base->surface);
|
focus_view(view, view->xdg_toplevel->base->surface);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -115,6 +105,41 @@ static void xdg_surface_destroy(struct wl_listener *listener, void *data) {
|
||||||
free(view);
|
free(view);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void xdg_toplevel_request_maximize(struct wl_listener *listener, void *data) {
|
||||||
|
struct wlr_xdg_surface *surface = data;
|
||||||
|
struct wb_view *view = wl_container_of(listener, view, request_maximize);
|
||||||
|
|
||||||
|
double closest_x, closest_y;
|
||||||
|
struct wlr_box geo_box;
|
||||||
|
struct wlr_output *output = NULL;
|
||||||
|
wlr_xdg_surface_get_geometry(surface, &geo_box);
|
||||||
|
wlr_output_layout_closest_point(view->server->output_layout, output, view->x + geo_box.width / 2, view->y + geo_box.height / 2, &closest_x, &closest_y);
|
||||||
|
output = wlr_output_layout_output_at(view->server->output_layout, closest_x, closest_y);
|
||||||
|
|
||||||
|
bool is_maximized = surface->toplevel->current.maximized;
|
||||||
|
struct wlr_box usable_area = {0};
|
||||||
|
if (!is_maximized) {
|
||||||
|
wlr_output_effective_resolution(output, &usable_area.width, &usable_area.height);
|
||||||
|
view->origdim.height = geo_box.height;
|
||||||
|
view->origdim.width = geo_box.width;
|
||||||
|
view->origdim.x = view->x;
|
||||||
|
view->origdim.y = view->y;
|
||||||
|
view->x = 0;
|
||||||
|
view->y = 0;
|
||||||
|
} else {
|
||||||
|
usable_area = view->origdim;
|
||||||
|
view->x = view->origdim.x;
|
||||||
|
view->y = view->origdim.y;
|
||||||
|
}
|
||||||
|
#if WLR_CHECK_VERSION(0, 16, 0)
|
||||||
|
wlr_xdg_toplevel_set_size(surface->toplevel, usable_area.width, usable_area.height);
|
||||||
|
wlr_xdg_toplevel_set_maximized(surface->toplevel, !is_maximized);
|
||||||
|
#else
|
||||||
|
wlr_xdg_toplevel_set_size(surface, usable_area.width, usable_area.height);
|
||||||
|
wlr_xdg_toplevel_set_maximized(surface, !is_maximized);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
static void begin_interactive(struct wb_view *view,
|
static void begin_interactive(struct wb_view *view,
|
||||||
enum wb_cursor_mode mode, uint32_t edges) {
|
enum wb_cursor_mode mode, uint32_t edges) {
|
||||||
/* This function sets up an interactive move or resize operation, where the
|
/* This function sets up an interactive move or resize operation, where the
|
||||||
|
|
@ -185,12 +210,13 @@ static void handle_new_xdg_surface(struct wl_listener *listener, void *data) {
|
||||||
view->server = server;
|
view->server = server;
|
||||||
view->xdg_toplevel = xdg_surface->toplevel;
|
view->xdg_toplevel = xdg_surface->toplevel;
|
||||||
#if !WLR_CHECK_VERSION(0, 16, 0)
|
#if !WLR_CHECK_VERSION(0, 16, 0)
|
||||||
view->xdg_surface = view->xdg_toplevel->base;
|
view->xdg_surface = xdg_surface;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Listen to the various events it can emit */
|
/* Listen to the various events it can emit */
|
||||||
view->ack_configure.notify = xdg_surface_ack_configure;
|
view->surface_commit.notify = xdg_surface_commit;
|
||||||
wl_signal_add(&xdg_surface->events.ack_configure, &view->ack_configure);
|
wl_signal_add(&xdg_surface->surface->events.commit, &view->surface_commit);
|
||||||
|
|
||||||
view->map.notify = xdg_surface_map;
|
view->map.notify = xdg_surface_map;
|
||||||
wl_signal_add(&xdg_surface->events.map, &view->map);
|
wl_signal_add(&xdg_surface->events.map, &view->map);
|
||||||
view->unmap.notify = xdg_surface_unmap;
|
view->unmap.notify = xdg_surface_unmap;
|
||||||
|
|
@ -198,10 +224,13 @@ static void handle_new_xdg_surface(struct wl_listener *listener, void *data) {
|
||||||
view->destroy.notify = xdg_surface_destroy;
|
view->destroy.notify = xdg_surface_destroy;
|
||||||
wl_signal_add(&xdg_surface->events.destroy, &view->destroy);
|
wl_signal_add(&xdg_surface->events.destroy, &view->destroy);
|
||||||
|
|
||||||
|
struct wlr_xdg_toplevel *toplevel = view->xdg_toplevel;
|
||||||
|
view->request_maximize.notify = xdg_toplevel_request_maximize;
|
||||||
|
wl_signal_add(&toplevel->events.request_maximize, &view->request_maximize);
|
||||||
view->request_move.notify = xdg_toplevel_request_move;
|
view->request_move.notify = xdg_toplevel_request_move;
|
||||||
wl_signal_add(&view->xdg_toplevel->events.request_move, &view->request_move);
|
wl_signal_add(&toplevel->events.request_move, &view->request_move);
|
||||||
view->request_resize.notify = xdg_toplevel_request_resize;
|
view->request_resize.notify = xdg_toplevel_request_resize;
|
||||||
wl_signal_add(&view->xdg_toplevel->events.request_resize, &view->request_resize);
|
wl_signal_add(&toplevel->events.request_resize, &view->request_resize);
|
||||||
|
|
||||||
/* Add it to the list of views. */
|
/* Add it to the list of views. */
|
||||||
wl_list_insert(&server->views, &view->link);
|
wl_list_insert(&server->views, &view->link);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue