mirror of
https://github.com/mpv-player/mpv
synced 2025-01-26 01:23:17 +00:00
x11: factor out normal window resize code
As preparation for resizing the window with input commands in the following commit. Since there are already so many functions which somehow resize the window, add the word "highlevel" to the name of this new function.
This commit is contained in:
parent
2537f6f467
commit
b55d557822
@ -1146,6 +1146,32 @@ static void vo_x11_map_window(struct vo *vo, int x, int y, int w, int h)
|
|||||||
vo_x11_clearwindow(vo, x11->window);
|
vo_x11_clearwindow(vo, x11->window);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void vo_x11_highlevel_resize(struct vo *vo, int x, int y, int w, int h)
|
||||||
|
{
|
||||||
|
struct mp_vo_opts *opts = vo->opts;
|
||||||
|
struct vo_x11_state *x11 = vo->x11;
|
||||||
|
|
||||||
|
bool reset_pos = opts->force_window_position;
|
||||||
|
if (reset_pos) {
|
||||||
|
x11->nofs_x = x;
|
||||||
|
x11->nofs_y = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
x11->nofs_width = w;
|
||||||
|
x11->nofs_height = h;
|
||||||
|
|
||||||
|
if (opts->fullscreen) {
|
||||||
|
x11->size_changed_during_fs = true;
|
||||||
|
x11->pos_changed_during_fs = reset_pos;
|
||||||
|
vo_x11_sizehint(vo, x, y, w, h, false);
|
||||||
|
} else {
|
||||||
|
vo_x11_move_resize(vo, reset_pos, true, x, y, w, h);
|
||||||
|
}
|
||||||
|
|
||||||
|
vo_x11_update_geometry(vo);
|
||||||
|
update_vo_size(vo);
|
||||||
|
}
|
||||||
|
|
||||||
/* Create and setup a window suitable for display
|
/* Create and setup a window suitable for display
|
||||||
* vis: Visual to use for creating the window (NULL for default)
|
* vis: Visual to use for creating the window (NULL for default)
|
||||||
* x, y: position of window (might be ignored)
|
* x, y: position of window (might be ignored)
|
||||||
@ -1179,36 +1205,18 @@ void vo_x11_config_vo_window(struct vo *vo, XVisualInfo *vis, int x, int y,
|
|||||||
if (flags & VOFLAG_HIDDEN)
|
if (flags & VOFLAG_HIDDEN)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
bool reset_size = !(x11->old_dwidth == width && x11->old_dheight == height);
|
bool reset_size = x11->old_dwidth != width || x11->old_dheight != height;
|
||||||
if (x11->window_hidden) {
|
|
||||||
x11->nofs_x = x;
|
|
||||||
x11->nofs_y = y;
|
|
||||||
reset_size = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
x11->old_dwidth = width;
|
x11->old_dwidth = width;
|
||||||
x11->old_dheight = height;
|
x11->old_dheight = height;
|
||||||
|
|
||||||
if (reset_size) {
|
if (x11->window_hidden) {
|
||||||
|
x11->nofs_x = x;
|
||||||
|
x11->nofs_y = y;
|
||||||
x11->nofs_width = width;
|
x11->nofs_width = width;
|
||||||
x11->nofs_height = height;
|
x11->nofs_height = height;
|
||||||
}
|
|
||||||
|
|
||||||
if (x11->window_hidden) {
|
|
||||||
vo_x11_map_window(vo, x, y, width, height);
|
vo_x11_map_window(vo, x, y, width, height);
|
||||||
} else if (reset_size) {
|
} else if (reset_size) {
|
||||||
bool reset_pos = opts->force_window_position;
|
vo_x11_highlevel_resize(vo, x, y, width, height);
|
||||||
if (reset_pos) {
|
|
||||||
x11->nofs_x = x;
|
|
||||||
x11->nofs_y = y;
|
|
||||||
}
|
|
||||||
if (opts->fullscreen) {
|
|
||||||
x11->size_changed_during_fs = true;
|
|
||||||
x11->pos_changed_during_fs = reset_pos;
|
|
||||||
vo_x11_sizehint(vo, x, y, width, height, false);
|
|
||||||
} else {
|
|
||||||
vo_x11_move_resize(vo, reset_pos, true, x, y, width, height);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opts->ontop)
|
if (opts->ontop)
|
||||||
|
Loading…
Reference in New Issue
Block a user