|
|
@ -48,10 +48,10 @@ struct roots_view *view_create(struct roots_desktop *desktop) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_get_box(const struct roots_view *view, struct wlr_box *box) {
|
|
|
|
void view_get_box(const struct roots_view *view, struct wlr_box *box) {
|
|
|
|
box->x = view->x;
|
|
|
|
box->x = view->box.x;
|
|
|
|
box->y = view->y;
|
|
|
|
box->y = view->box.y;
|
|
|
|
box->width = view->width;
|
|
|
|
box->width = view->box.width;
|
|
|
|
box->height = view->height;
|
|
|
|
box->height = view->box.height;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_get_deco_box(const struct roots_view *view, struct wlr_box *box) {
|
|
|
|
void view_get_deco_box(const struct roots_view *view, struct wlr_box *box) {
|
|
|
@ -131,7 +131,7 @@ static void view_update_output(const struct roots_view *view,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_move(struct roots_view *view, double x, double y) {
|
|
|
|
void view_move(struct roots_view *view, double x, double y) {
|
|
|
|
if (view->x == x && view->y == y) {
|
|
|
|
if (view->box.x == x && view->box.y == y) {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -162,8 +162,8 @@ void view_resize(struct roots_view *view, uint32_t width, uint32_t height) {
|
|
|
|
|
|
|
|
|
|
|
|
void view_move_resize(struct roots_view *view, double x, double y,
|
|
|
|
void view_move_resize(struct roots_view *view, double x, double y,
|
|
|
|
uint32_t width, uint32_t height) {
|
|
|
|
uint32_t width, uint32_t height) {
|
|
|
|
bool update_x = x != view->x;
|
|
|
|
bool update_x = x != view->box.x;
|
|
|
|
bool update_y = y != view->y;
|
|
|
|
bool update_y = y != view->box.y;
|
|
|
|
if (!update_x && !update_y) {
|
|
|
|
if (!update_x && !update_y) {
|
|
|
|
view_resize(view, width, height);
|
|
|
|
view_resize(view, width, height);
|
|
|
|
return;
|
|
|
|
return;
|
|
|
@ -190,8 +190,8 @@ static struct wlr_output *view_get_output(struct roots_view *view) {
|
|
|
|
|
|
|
|
|
|
|
|
double output_x, output_y;
|
|
|
|
double output_x, output_y;
|
|
|
|
wlr_output_layout_closest_point(view->desktop->layout, NULL,
|
|
|
|
wlr_output_layout_closest_point(view->desktop->layout, NULL,
|
|
|
|
view->x + (double)view_box.width/2,
|
|
|
|
view->box.x + (double)view_box.width/2,
|
|
|
|
view->y + (double)view_box.height/2,
|
|
|
|
view->box.y + (double)view_box.height/2,
|
|
|
|
&output_x, &output_y);
|
|
|
|
&output_x, &output_y);
|
|
|
|
return wlr_output_layout_output_at(view->desktop->layout, output_x,
|
|
|
|
return wlr_output_layout_output_at(view->desktop->layout, output_x,
|
|
|
|
output_y);
|
|
|
|
output_y);
|
|
|
@ -227,11 +227,11 @@ void view_maximize(struct roots_view *view, bool maximized) {
|
|
|
|
|
|
|
|
|
|
|
|
if (!view->maximized && maximized) {
|
|
|
|
if (!view->maximized && maximized) {
|
|
|
|
view->maximized = true;
|
|
|
|
view->maximized = true;
|
|
|
|
view->saved.x = view->x;
|
|
|
|
view->saved.x = view->box.x;
|
|
|
|
view->saved.y = view->y;
|
|
|
|
view->saved.y = view->box.y;
|
|
|
|
view->saved.rotation = view->rotation;
|
|
|
|
view->saved.rotation = view->rotation;
|
|
|
|
view->saved.width = view->width;
|
|
|
|
view->saved.width = view->box.width;
|
|
|
|
view->saved.height = view->height;
|
|
|
|
view->saved.height = view->box.height;
|
|
|
|
|
|
|
|
|
|
|
|
view_arrange_maximized(view);
|
|
|
|
view_arrange_maximized(view);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -272,8 +272,8 @@ void view_set_fullscreen(struct roots_view *view, bool fullscreen,
|
|
|
|
struct wlr_box view_box;
|
|
|
|
struct wlr_box view_box;
|
|
|
|
view_get_box(view, &view_box);
|
|
|
|
view_get_box(view, &view_box);
|
|
|
|
|
|
|
|
|
|
|
|
view->saved.x = view->x;
|
|
|
|
view->saved.x = view->box.x;
|
|
|
|
view->saved.y = view->y;
|
|
|
|
view->saved.y = view->box.y;
|
|
|
|
view->saved.rotation = view->rotation;
|
|
|
|
view->saved.rotation = view->rotation;
|
|
|
|
view->saved.width = view_box.width;
|
|
|
|
view->saved.width = view_box.width;
|
|
|
|
view->saved.height = view_box.height;
|
|
|
|
view->saved.height = view_box.height;
|
|
|
@ -500,7 +500,7 @@ void view_unmap(struct roots_view *view) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
view->wlr_surface = NULL;
|
|
|
|
view->wlr_surface = NULL;
|
|
|
|
view->width = view->height = 0;
|
|
|
|
view->box.width = view->box.height = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_initial_focus(struct roots_view *view) {
|
|
|
|
void view_initial_focus(struct roots_view *view) {
|
|
|
@ -536,25 +536,25 @@ void view_damage_whole(struct roots_view *view) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_update_position(struct roots_view *view, double x, double y) {
|
|
|
|
void view_update_position(struct roots_view *view, int x, int y) {
|
|
|
|
if (view->x == x && view->y == y) {
|
|
|
|
if (view->box.x == x && view->box.y == y) {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
view_damage_whole(view);
|
|
|
|
view_damage_whole(view);
|
|
|
|
view->x = x;
|
|
|
|
view->box.x = x;
|
|
|
|
view->y = y;
|
|
|
|
view->box.y = y;
|
|
|
|
view_damage_whole(view);
|
|
|
|
view_damage_whole(view);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void view_update_size(struct roots_view *view, uint32_t width, uint32_t height) {
|
|
|
|
void view_update_size(struct roots_view *view, int width, int height) {
|
|
|
|
if (view->width == width && view->height == height) {
|
|
|
|
if (view->box.width == width && view->box.height == height) {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
view_damage_whole(view);
|
|
|
|
view_damage_whole(view);
|
|
|
|
view->width = width;
|
|
|
|
view->box.width = width;
|
|
|
|
view->height = height;
|
|
|
|
view->box.height = height;
|
|
|
|
view_damage_whole(view);
|
|
|
|
view_damage_whole(view);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -585,8 +585,8 @@ static bool view_at(struct roots_view *view, double lx, double ly,
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
double view_sx = lx - view->x;
|
|
|
|
double view_sx = lx - view->box.x;
|
|
|
|
double view_sy = ly - view->y;
|
|
|
|
double view_sy = ly - view->box.y;
|
|
|
|
|
|
|
|
|
|
|
|
struct wlr_surface_state *state = &view->wlr_surface->current;
|
|
|
|
struct wlr_surface_state *state = &view->wlr_surface->current;
|
|
|
|
struct wlr_box box = {
|
|
|
|
struct wlr_box box = {
|
|
|
@ -806,10 +806,10 @@ static void handle_constraint_destroy(struct wl_listener *listener,
|
|
|
|
double sy = wlr_constraint->current.cursor_hint.y;
|
|
|
|
double sy = wlr_constraint->current.cursor_hint.y;
|
|
|
|
|
|
|
|
|
|
|
|
struct roots_view *view = seat->cursor->pointer_view->view;
|
|
|
|
struct roots_view *view = seat->cursor->pointer_view->view;
|
|
|
|
rotate_child_position(&sx, &sy, 0, 0, view->width, view->height,
|
|
|
|
rotate_child_position(&sx, &sy, 0, 0, view->box.width, view->box.height,
|
|
|
|
view->rotation);
|
|
|
|
view->rotation);
|
|
|
|
double lx = view->x + sx;
|
|
|
|
double lx = view->box.x + sx;
|
|
|
|
double ly = view->y + sy;
|
|
|
|
double ly = view->box.y + sy;
|
|
|
|
|
|
|
|
|
|
|
|
wlr_cursor_warp(seat->cursor->cursor, NULL, lx, ly);
|
|
|
|
wlr_cursor_warp(seat->cursor->cursor, NULL, lx, ly);
|
|
|
|
}
|
|
|
|
}
|
|
|
|