mirror of
https://github.com/mpv-player/mpv
synced 2025-01-19 05:41:16 +00:00
win32: fit_window_on_screen: simplify, add comments
The fit_on_screen logic was a bit twisted. Simplify it a bit and update few comments to explain better what it's used for. Note that the new logic is not identical to before, but its intent should now be clearer. This means there might be regressions or improvements at edge cases. If followup fixes are needed, then we should keep the intent clear. Most likely though that it's fine.
This commit is contained in:
parent
954f6ac7bf
commit
f60e327e49
@ -103,8 +103,9 @@ struct vo_w32_state {
|
|||||||
bool current_fs;
|
bool current_fs;
|
||||||
bool toggle_fs; // whether the current fullscreen state needs to be switched
|
bool toggle_fs; // whether the current fullscreen state needs to be switched
|
||||||
|
|
||||||
RECT windowrc; // currently known window rect
|
// Note: maximized state doesn't involve nor modify windowrc
|
||||||
RECT prev_windowrc; // last non-fullscreen window rect
|
RECT windowrc; // currently known normal/fullscreen window client rect
|
||||||
|
RECT prev_windowrc; // saved normal window client rect while in fullscreen
|
||||||
|
|
||||||
// video size
|
// video size
|
||||||
uint32_t o_dwidth;
|
uint32_t o_dwidth;
|
||||||
@ -129,7 +130,13 @@ struct vo_w32_state {
|
|||||||
// UTF-16 decoding state for WM_CHAR and VK_PACKET
|
// UTF-16 decoding state for WM_CHAR and VK_PACKET
|
||||||
int high_surrogate;
|
int high_surrogate;
|
||||||
|
|
||||||
// Whether to fit the window on screen on next window state updating
|
// Fit the window to one monitor working area next time it's not fullscreen
|
||||||
|
// and not maximized. Used once after every new "untrusted" size comes from
|
||||||
|
// mpv, else we assume that the last known size is valid and don't fit.
|
||||||
|
// FIXME: on a multi-monitor setup one bit is not enough, because the first
|
||||||
|
// fit (autofit etc) should be to one monitor, but later size changes from
|
||||||
|
// mpv like window-scale (VOCTRL_SET_UNFS_WINDOW_SIZE) should allow the
|
||||||
|
// entire virtual desktop area - but we still limit to one monitor size.
|
||||||
bool fit_on_screen;
|
bool fit_on_screen;
|
||||||
|
|
||||||
ITaskbarList2 *taskbar_list;
|
ITaskbarList2 *taskbar_list;
|
||||||
@ -848,11 +855,10 @@ static void fit_window_on_screen(struct vo_w32_state *w32)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Calculate new fullscreen state and change window size and position.
|
// Calculate new fullscreen state and change window size and position.
|
||||||
// returns true if fullscreen state was changed.
|
static void update_fullscreen_state(struct vo_w32_state *w32)
|
||||||
static bool update_fullscreen_state(struct vo_w32_state *w32)
|
|
||||||
{
|
{
|
||||||
if (w32->parent)
|
if (w32->parent)
|
||||||
return false;
|
return;
|
||||||
|
|
||||||
bool new_fs = w32->opts->fullscreen;
|
bool new_fs = w32->opts->fullscreen;
|
||||||
if (w32->toggle_fs) {
|
if (w32->toggle_fs) {
|
||||||
@ -884,7 +890,6 @@ static bool update_fullscreen_state(struct vo_w32_state *w32)
|
|||||||
MP_VERBOSE(w32, "reset window bounds: %d:%d:%d:%d\n",
|
MP_VERBOSE(w32, "reset window bounds: %d:%d:%d:%d\n",
|
||||||
(int)w32->windowrc.left, (int)w32->windowrc.top,
|
(int)w32->windowrc.left, (int)w32->windowrc.top,
|
||||||
(int)rect_w(w32->windowrc), (int)rect_h(w32->windowrc));
|
(int)rect_w(w32->windowrc), (int)rect_h(w32->windowrc));
|
||||||
return toggle_fs;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void update_minimized_state(struct vo_w32_state *w32)
|
static void update_minimized_state(struct vo_w32_state *w32)
|
||||||
@ -978,17 +983,13 @@ static void reinit_window_state(struct vo_w32_state *w32)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
// The order matters: fs state should be updated prior to changing styles
|
// The order matters: fs state should be updated prior to changing styles
|
||||||
bool toggle_fs = update_fullscreen_state(w32);
|
update_fullscreen_state(w32);
|
||||||
update_window_style(w32);
|
update_window_style(w32);
|
||||||
|
|
||||||
// Assume that the window has already been fit on screen before switching fs
|
// fit_on_screen is applied at most once when/if applicable (normal win).
|
||||||
if (!toggle_fs || w32->fit_on_screen) {
|
if (w32->fit_on_screen && !w32->current_fs && !IsMaximized(w32->window)) {
|
||||||
if (!w32->current_fs && !IsMaximized(w32->window))
|
fit_window_on_screen(w32);
|
||||||
fit_window_on_screen(w32);
|
w32->fit_on_screen = false;
|
||||||
|
|
||||||
// The fullscreen state might still be active, so set the flag
|
|
||||||
// to fit on screen next time the window leaves the fullscreen.
|
|
||||||
w32->fit_on_screen = w32->current_fs;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Show and activate the window after all window state parameters were set
|
// Show and activate the window after all window state parameters were set
|
||||||
|
Loading…
Reference in New Issue
Block a user