desktop-shell: add output co-ordinates to get_output_work_area()
get_output_work_area() now returns the absolute work area including the output's offset. This will make math a little simpler later when we use it to constrain window moves. Signed-off-by: Derek Foreman <derekf@osg.samsung.com> Reviewed-by: Bryce Harrington <bryce@osg.samsung.com>
This commit is contained in:
parent
c68362329e
commit
f814c5dc9d
@ -460,21 +460,20 @@ get_output_work_area(struct desktop_shell *shell,
|
|||||||
{
|
{
|
||||||
int32_t panel_width = 0, panel_height = 0;
|
int32_t panel_width = 0, panel_height = 0;
|
||||||
|
|
||||||
area->x = 0;
|
area->x = output->x;
|
||||||
area->y = 0;
|
area->y = output->y;
|
||||||
|
|
||||||
get_output_panel_size(shell, output, &panel_width, &panel_height);
|
get_output_panel_size(shell, output, &panel_width, &panel_height);
|
||||||
|
|
||||||
switch (shell->panel_position) {
|
switch (shell->panel_position) {
|
||||||
case DESKTOP_SHELL_PANEL_POSITION_TOP:
|
case DESKTOP_SHELL_PANEL_POSITION_TOP:
|
||||||
default:
|
default:
|
||||||
area->y = panel_height;
|
area->y += panel_height;
|
||||||
case DESKTOP_SHELL_PANEL_POSITION_BOTTOM:
|
case DESKTOP_SHELL_PANEL_POSITION_BOTTOM:
|
||||||
area->width = output->width;
|
area->width = output->width;
|
||||||
area->height = output->height - panel_height;
|
area->height = output->height - panel_height;
|
||||||
break;
|
break;
|
||||||
case DESKTOP_SHELL_PANEL_POSITION_LEFT:
|
case DESKTOP_SHELL_PANEL_POSITION_LEFT:
|
||||||
area->x = panel_width;
|
area->x += panel_width;
|
||||||
case DESKTOP_SHELL_PANEL_POSITION_RIGHT:
|
case DESKTOP_SHELL_PANEL_POSITION_RIGHT:
|
||||||
area->width = output->width - panel_width;
|
area->width = output->width - panel_width;
|
||||||
area->height = output->height;
|
area->height = output->height;
|
||||||
@ -5437,7 +5436,7 @@ weston_view_set_initial_position(struct weston_view *view,
|
|||||||
struct weston_compositor *compositor = shell->compositor;
|
struct weston_compositor *compositor = shell->compositor;
|
||||||
int ix = 0, iy = 0;
|
int ix = 0, iy = 0;
|
||||||
int32_t range_x, range_y;
|
int32_t range_x, range_y;
|
||||||
int32_t dx, dy, x, y;
|
int32_t x, y;
|
||||||
struct weston_output *output, *target_output = NULL;
|
struct weston_output *output, *target_output = NULL;
|
||||||
struct weston_seat *seat;
|
struct weston_seat *seat;
|
||||||
pixman_rectangle32_t area;
|
pixman_rectangle32_t area;
|
||||||
@ -5474,19 +5473,16 @@ weston_view_set_initial_position(struct weston_view *view,
|
|||||||
*/
|
*/
|
||||||
get_output_work_area(shell, target_output, &area);
|
get_output_work_area(shell, target_output, &area);
|
||||||
|
|
||||||
dx = area.x;
|
x = area.x;
|
||||||
dy = area.y;
|
y = area.y;
|
||||||
range_x = area.width - view->surface->width;
|
range_x = area.width - view->surface->width;
|
||||||
range_y = area.height - view->surface->height;
|
range_y = area.height - view->surface->height;
|
||||||
|
|
||||||
if (range_x > 0)
|
if (range_x > 0)
|
||||||
dx += random() % range_x;
|
x += random() % range_x;
|
||||||
|
|
||||||
if (range_y > 0)
|
if (range_y > 0)
|
||||||
dy += random() % range_y;
|
y += random() % range_y;
|
||||||
|
|
||||||
x = target_output->x + dx;
|
|
||||||
y = target_output->y + dy;
|
|
||||||
|
|
||||||
weston_view_set_position(view, x, y);
|
weston_view_set_position(view, x, y);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user