mirror of
https://github.com/labwc/labwc.git
synced 2025-11-02 09:01:47 -05:00
view: add functions view_{un,}minimize
This commit is contained in:
parent
d782e48204
commit
49e499d255
4 changed files with 24 additions and 4 deletions
|
|
@ -178,6 +178,8 @@ void view_init_position(struct view *view);
|
||||||
struct wlr_box view_get_surface_geometry(struct view *view);
|
struct wlr_box view_get_surface_geometry(struct view *view);
|
||||||
struct wlr_box view_geometry(struct view *view);
|
struct wlr_box view_geometry(struct view *view);
|
||||||
void view_resize(struct view *view, struct wlr_box geo);
|
void view_resize(struct view *view, struct wlr_box geo);
|
||||||
|
void view_minimize(struct view *view);
|
||||||
|
void view_unminimize(struct view *view);
|
||||||
void view_focus(struct view *view);
|
void view_focus(struct view *view);
|
||||||
struct view *view_next(struct server *server, struct view *current);
|
struct view *view_next(struct server *server, struct view *current);
|
||||||
bool view_hasfocus(struct view *view);
|
bool view_hasfocus(struct view *view);
|
||||||
|
|
|
||||||
|
|
@ -202,7 +202,7 @@ void cursor_button(struct wl_listener *listener, void *data)
|
||||||
view->impl->close(view);
|
view->impl->close(view);
|
||||||
break;
|
break;
|
||||||
case LAB_DECO_BUTTON_ICONIFY:
|
case LAB_DECO_BUTTON_ICONIFY:
|
||||||
view->impl->unmap(view);
|
view_minimize(view);
|
||||||
break;
|
break;
|
||||||
case LAB_DECO_PART_TITLE:
|
case LAB_DECO_PART_TITLE:
|
||||||
interactive_begin(view, LAB_CURSOR_MOVE, 0);
|
interactive_begin(view, LAB_CURSOR_MOVE, 0);
|
||||||
|
|
|
||||||
|
|
@ -50,7 +50,7 @@ static void show_one_xwl_view(struct view *view)
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "-");
|
fprintf(stderr, "-");
|
||||||
}
|
}
|
||||||
fprintf(stderr, " %p.4 %s {%d,%d,%d,%d}\n", (void *)view,
|
fprintf(stderr, " %p %s {%d,%d,%d,%d}\n", (void *)view,
|
||||||
view->xwayland_surface->class, view->xwayland_surface->x,
|
view->xwayland_surface->class, view->xwayland_surface->x,
|
||||||
view->xwayland_surface->y, view->xwayland_surface->width,
|
view->xwayland_surface->y, view->xwayland_surface->width,
|
||||||
view->xwayland_surface->height);
|
view->xwayland_surface->height);
|
||||||
|
|
|
||||||
22
src/view.c
22
src/view.c
|
|
@ -69,6 +69,22 @@ void view_resize(struct view *view, struct wlr_box geo)
|
||||||
view->impl->configure(view, box);
|
view->impl->configure(view, box);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void view_minimize(struct view *view)
|
||||||
|
{
|
||||||
|
if (view->minimized == true)
|
||||||
|
return;
|
||||||
|
view->minimized = true;
|
||||||
|
view->impl->unmap(view);
|
||||||
|
}
|
||||||
|
|
||||||
|
void view_unminimize(struct view *view)
|
||||||
|
{
|
||||||
|
if (view->minimized == false)
|
||||||
|
return;
|
||||||
|
view->minimized = false;
|
||||||
|
view->impl->map(view);
|
||||||
|
}
|
||||||
|
|
||||||
static void move_to_front(struct view *view)
|
static void move_to_front(struct view *view)
|
||||||
{
|
{
|
||||||
wl_list_remove(&view->link);
|
wl_list_remove(&view->link);
|
||||||
|
|
@ -135,8 +151,8 @@ void view_focus(struct view *view)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* TODO: messy - sort out */
|
/* TODO: messy - sort out */
|
||||||
if (!view->mapped) {
|
if (!view->mapped && view->minimized) {
|
||||||
view->impl->map(view);
|
view_unminimize(view);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -270,6 +286,8 @@ struct view *view_at(struct server *server, double lx, double ly,
|
||||||
*/
|
*/
|
||||||
struct view *view;
|
struct view *view;
|
||||||
wl_list_for_each (view, &server->views, link) {
|
wl_list_for_each (view, &server->views, link) {
|
||||||
|
if (!view->mapped)
|
||||||
|
continue;
|
||||||
if (_view_at(view, lx, ly, surface, sx, sy))
|
if (_view_at(view, lx, ly, surface, sx, sy))
|
||||||
return view;
|
return view;
|
||||||
if (!view->show_server_side_deco)
|
if (!view->show_server_side_deco)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue