mirror of
https://github.com/labwc/labwc.git
synced 2025-11-03 09:01:51 -05:00
Merge branch 'maximize'
This commit is contained in:
commit
f5f8acc543
5 changed files with 132 additions and 3 deletions
|
|
@ -162,6 +162,7 @@ struct view_impl {
|
||||||
void (*map)(struct view *view);
|
void (*map)(struct view *view);
|
||||||
void (*move)(struct view *view, double x, double y);
|
void (*move)(struct view *view, double x, double y);
|
||||||
void (*unmap)(struct view *view);
|
void (*unmap)(struct view *view);
|
||||||
|
void (*maximize)(struct view *view, bool maximize);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct border {
|
struct border {
|
||||||
|
|
@ -188,6 +189,7 @@ struct view {
|
||||||
bool mapped;
|
bool mapped;
|
||||||
bool been_mapped;
|
bool been_mapped;
|
||||||
bool minimized;
|
bool minimized;
|
||||||
|
bool maximized;
|
||||||
|
|
||||||
/* geometry of the wlr_surface contained within the view */
|
/* geometry of the wlr_surface contained within the view */
|
||||||
int x, y, w, h;
|
int x, y, w, h;
|
||||||
|
|
@ -224,6 +226,7 @@ struct view {
|
||||||
struct wl_listener request_move;
|
struct wl_listener request_move;
|
||||||
struct wl_listener request_resize;
|
struct wl_listener request_resize;
|
||||||
struct wl_listener request_configure;
|
struct wl_listener request_configure;
|
||||||
|
struct wl_listener request_maximize;
|
||||||
struct wl_listener new_popup; /* xdg-shell only */
|
struct wl_listener new_popup; /* xdg-shell only */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -266,6 +269,7 @@ void view_move_resize(struct view *view, struct wlr_box geo);
|
||||||
void view_move(struct view *view, double x, double y);
|
void view_move(struct view *view, double x, double y);
|
||||||
void view_minimize(struct view *view);
|
void view_minimize(struct view *view);
|
||||||
void view_unminimize(struct view *view);
|
void view_unminimize(struct view *view);
|
||||||
|
void view_maximize(struct view *view, bool maximize);
|
||||||
void view_for_each_surface(struct view *view,
|
void view_for_each_surface(struct view *view,
|
||||||
wlr_surface_iterator_func_t iterator, void *user_data);
|
wlr_surface_iterator_func_t iterator, void *user_data);
|
||||||
void view_for_each_popup(struct view *view,
|
void view_for_each_popup(struct view *view,
|
||||||
|
|
@ -281,8 +285,8 @@ void desktop_focus_view(struct seat *seat, struct view *view);
|
||||||
struct view *desktop_cycle_view(struct server *server, struct view *current);
|
struct view *desktop_cycle_view(struct server *server, struct view *current);
|
||||||
void desktop_focus_topmost_mapped_view(struct server *server);
|
void desktop_focus_topmost_mapped_view(struct server *server);
|
||||||
struct view *desktop_view_at(struct server *server, double lx, double ly,
|
struct view *desktop_view_at(struct server *server, double lx, double ly,
|
||||||
struct wlr_surface **surface, double *sx,
|
struct wlr_surface **surface, double *sx,
|
||||||
double *sy, int *view_area);
|
double *sy, int *view_area);
|
||||||
|
|
||||||
void cursor_init(struct seat *seat);
|
void cursor_init(struct seat *seat);
|
||||||
|
|
||||||
|
|
@ -294,7 +298,7 @@ void seat_focus_surface(struct seat *seat, struct wlr_surface *surface);
|
||||||
void seat_set_focus_layer(struct seat *seat, struct wlr_layer_surface_v1 *layer);
|
void seat_set_focus_layer(struct seat *seat, struct wlr_layer_surface_v1 *layer);
|
||||||
|
|
||||||
void interactive_begin(struct view *view, enum input_mode mode,
|
void interactive_begin(struct view *view, enum input_mode mode,
|
||||||
uint32_t edges);
|
uint32_t edges);
|
||||||
|
|
||||||
void output_init(struct server *server);
|
void output_init(struct server *server);
|
||||||
void output_damage_surface(struct output *output, struct wlr_surface *surface,
|
void output_damage_surface(struct output *output, struct wlr_surface *surface,
|
||||||
|
|
|
||||||
|
|
@ -320,6 +320,9 @@ cursor_button(struct wl_listener *listener, void *data)
|
||||||
case LAB_DECO_PART_TITLE:
|
case LAB_DECO_PART_TITLE:
|
||||||
interactive_begin(view, LAB_INPUT_STATE_MOVE, 0);
|
interactive_begin(view, LAB_INPUT_STATE_MOVE, 0);
|
||||||
break;
|
break;
|
||||||
|
case LAB_DECO_BUTTON_MAXIMIZE:
|
||||||
|
view_maximize(view, !view->maximized);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
67
src/view.c
67
src/view.c
|
|
@ -1,5 +1,7 @@
|
||||||
#include "labwc.h"
|
#include "labwc.h"
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <assert.h>
|
||||||
void
|
void
|
||||||
view_move_resize(struct view *view, struct wlr_box geo)
|
view_move_resize(struct view *view, struct wlr_box geo)
|
||||||
{
|
{
|
||||||
|
|
@ -32,6 +34,71 @@ view_unminimize(struct view *view)
|
||||||
view->impl->map(view);
|
view->impl->map(view);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
view_maximize(struct view *view, bool maximize)
|
||||||
|
{
|
||||||
|
if(maximize == true)
|
||||||
|
{
|
||||||
|
struct wlr_output_layout *layout = view->server->output_layout;
|
||||||
|
struct wlr_output* output =
|
||||||
|
wlr_output_layout_output_at(layout, view->x, view->y);
|
||||||
|
struct wlr_output_layout_output* ol_output =
|
||||||
|
wlr_output_layout_get(layout, output);
|
||||||
|
|
||||||
|
assert(layout);
|
||||||
|
if(output == NULL)
|
||||||
|
{
|
||||||
|
die("output NULL w/ x and y of: %d, %d", view->x, view->y);
|
||||||
|
}
|
||||||
|
assert(output);
|
||||||
|
assert(ol_output);
|
||||||
|
|
||||||
|
int x = ol_output->x;
|
||||||
|
int y = ol_output->y;
|
||||||
|
int width = output->width;
|
||||||
|
int height = output->height;
|
||||||
|
|
||||||
|
if(view->server_side_deco)
|
||||||
|
{
|
||||||
|
struct border border = deco_thickness(view);
|
||||||
|
x += border.right;
|
||||||
|
x += border.left;
|
||||||
|
y += border.top;
|
||||||
|
y += border.bottom;
|
||||||
|
|
||||||
|
width -= border.right;
|
||||||
|
width -= border.left;
|
||||||
|
height -= border.top;
|
||||||
|
height -= border.bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct wlr_box box = {
|
||||||
|
.x = x * output->scale,
|
||||||
|
.y = y * output->scale,
|
||||||
|
.width = width * output->scale,
|
||||||
|
.height = height * output->scale
|
||||||
|
};
|
||||||
|
|
||||||
|
view_move_resize(view, box);
|
||||||
|
view_move(view, box.x * output->scale, box.y * output->scale);
|
||||||
|
|
||||||
|
view->maximized = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
struct wlr_box box = {
|
||||||
|
.x = 20,
|
||||||
|
.y = 50,
|
||||||
|
.width = 640,
|
||||||
|
.height = 480
|
||||||
|
};
|
||||||
|
|
||||||
|
view_move_resize(view, box);
|
||||||
|
view->maximized = false;
|
||||||
|
}
|
||||||
|
view->impl->maximize(view, maximize);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
view_for_each_surface(struct view *view, wlr_surface_iterator_func_t iterator,
|
view_for_each_surface(struct view *view, wlr_surface_iterator_func_t iterator,
|
||||||
void *user_data)
|
void *user_data)
|
||||||
|
|
|
||||||
35
src/xdg.c
35
src/xdg.c
|
|
@ -230,6 +230,26 @@ handle_request_resize(struct wl_listener *listener, void *data)
|
||||||
interactive_begin(view, LAB_INPUT_STATE_RESIZE, event->edges);
|
interactive_begin(view, LAB_INPUT_STATE_RESIZE, event->edges);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_request_maximize(struct wl_listener *listener, void *data)
|
||||||
|
{
|
||||||
|
/* This event is raised when a client would like to begin an interactive
|
||||||
|
* resize, typically because the user clicked on their client-side
|
||||||
|
* decorations. Note that a more sophisticated compositor should check
|
||||||
|
* the provied serial against a list of button press serials sent to
|
||||||
|
* this
|
||||||
|
* client, to prevent the client from requesting this whenever they want.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct view *view = wl_container_of(listener, view, request_maximize);
|
||||||
|
|
||||||
|
struct wlr_xdg_surface *surface = data;
|
||||||
|
if(view != NULL) {
|
||||||
|
view_maximize(view, surface->toplevel->client_pending.maximized);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xdg_toplevel_view_configure(struct view *view, struct wlr_box geo)
|
xdg_toplevel_view_configure(struct view *view, struct wlr_box geo)
|
||||||
{
|
{
|
||||||
|
|
@ -279,6 +299,12 @@ xdg_toplevel_view_for_each_surface(struct view *view,
|
||||||
wlr_xdg_surface_for_each_surface(view->xdg_surface, iterator, data);
|
wlr_xdg_surface_for_each_surface(view->xdg_surface, iterator, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
xdg_toplevel_view_maximize(struct view *view, bool maximized)
|
||||||
|
{
|
||||||
|
wlr_xdg_toplevel_set_maximized(view->xdg_surface, maximized);
|
||||||
|
}
|
||||||
|
|
||||||
/* Return area between surface extremities and window */
|
/* Return area between surface extremities and window */
|
||||||
static struct border
|
static struct border
|
||||||
xdg_shell_padding(struct view *view)
|
xdg_shell_padding(struct view *view)
|
||||||
|
|
@ -347,6 +373,7 @@ static const struct view_impl xdg_toplevel_view_impl = {
|
||||||
.map = xdg_toplevel_view_map,
|
.map = xdg_toplevel_view_map,
|
||||||
.move = xdg_toplevel_view_move,
|
.move = xdg_toplevel_view_move,
|
||||||
.unmap = xdg_toplevel_view_unmap,
|
.unmap = xdg_toplevel_view_unmap,
|
||||||
|
.maximize = xdg_toplevel_view_maximize
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
@ -365,6 +392,7 @@ xdg_surface_new(struct wl_listener *listener, void *data)
|
||||||
view->type = LAB_XDG_SHELL_VIEW;
|
view->type = LAB_XDG_SHELL_VIEW;
|
||||||
view->impl = &xdg_toplevel_view_impl;
|
view->impl = &xdg_toplevel_view_impl;
|
||||||
view->xdg_surface = xdg_surface;
|
view->xdg_surface = xdg_surface;
|
||||||
|
view->maximized = false;
|
||||||
|
|
||||||
view->map.notify = handle_map;
|
view->map.notify = handle_map;
|
||||||
wl_signal_add(&xdg_surface->events.map, &view->map);
|
wl_signal_add(&xdg_surface->events.map, &view->map);
|
||||||
|
|
@ -381,6 +409,13 @@ xdg_surface_new(struct wl_listener *listener, void *data)
|
||||||
wl_signal_add(&toplevel->events.request_move, &view->request_move);
|
wl_signal_add(&toplevel->events.request_move, &view->request_move);
|
||||||
view->request_resize.notify = handle_request_resize;
|
view->request_resize.notify = handle_request_resize;
|
||||||
wl_signal_add(&toplevel->events.request_resize, &view->request_resize);
|
wl_signal_add(&toplevel->events.request_resize, &view->request_resize);
|
||||||
|
view->request_maximize.notify = handle_request_maximize;
|
||||||
|
wl_signal_add(&toplevel->events.request_maximize, &view->request_maximize);
|
||||||
|
|
||||||
|
// hacky workaround to bug where sometimes a window starts maximized and
|
||||||
|
// when we hit the maximize button, labwc crashes. instead we unmaximize
|
||||||
|
// it from the start to avoid this situation
|
||||||
|
view_maximize(view, false);
|
||||||
|
|
||||||
wl_list_insert(&server->views, &view->link);
|
wl_list_insert(&server->views, &view->link);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -47,6 +47,7 @@ handle_destroy(struct wl_listener *listener, void *data)
|
||||||
wl_list_remove(&view->unmap.link);
|
wl_list_remove(&view->unmap.link);
|
||||||
wl_list_remove(&view->destroy.link);
|
wl_list_remove(&view->destroy.link);
|
||||||
wl_list_remove(&view->request_configure.link);
|
wl_list_remove(&view->request_configure.link);
|
||||||
|
wl_list_remove(&view->request_maximize.link);
|
||||||
free(view);
|
free(view);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -60,6 +61,16 @@ handle_request_configure(struct wl_listener *listener, void *data)
|
||||||
damage_all_outputs(view->server);
|
damage_all_outputs(view->server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void handle_request_maximize(struct wl_listener *listener, void *data)
|
||||||
|
{
|
||||||
|
struct view *view = wl_container_of(listener, view, request_maximize);
|
||||||
|
|
||||||
|
if(view != NULL) {
|
||||||
|
view_maximize(view, !view->maximized);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
configure(struct view *view, struct wlr_box geo)
|
configure(struct view *view, struct wlr_box geo)
|
||||||
{
|
{
|
||||||
|
|
@ -159,6 +170,12 @@ unmap(struct view *view)
|
||||||
desktop_focus_topmost_mapped_view(view->server);
|
desktop_focus_topmost_mapped_view(view->server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
maximize(struct view *view, bool maximized)
|
||||||
|
{
|
||||||
|
wlr_xwayland_surface_set_maximized(view->xwayland_surface, maximized);
|
||||||
|
}
|
||||||
|
|
||||||
static const struct view_impl xwl_view_impl = {
|
static const struct view_impl xwl_view_impl = {
|
||||||
.configure = configure,
|
.configure = configure,
|
||||||
.close = _close,
|
.close = _close,
|
||||||
|
|
@ -166,6 +183,7 @@ static const struct view_impl xwl_view_impl = {
|
||||||
.map = map,
|
.map = map,
|
||||||
.move = move,
|
.move = move,
|
||||||
.unmap = unmap,
|
.unmap = unmap,
|
||||||
|
.maximize = maximize
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
@ -200,6 +218,8 @@ xwayland_surface_new(struct wl_listener *listener, void *data)
|
||||||
view->request_configure.notify = handle_request_configure;
|
view->request_configure.notify = handle_request_configure;
|
||||||
wl_signal_add(&xsurface->events.request_configure,
|
wl_signal_add(&xsurface->events.request_configure,
|
||||||
&view->request_configure);
|
&view->request_configure);
|
||||||
|
view->request_maximize.notify = handle_request_maximize;
|
||||||
|
wl_signal_add(&xsurface->events.request_maximize, &view->request_maximize);
|
||||||
|
|
||||||
wl_list_insert(&view->server->views, &view->link);
|
wl_list_insert(&view->server->views, &view->link);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue