mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-27 02:02:26 +00:00
RDB's general resizing cleanup. He's put his favourite resize mode
back in again, but as long as it's not the default it doesn't bother me too much :-) [originally from svn r1421]
This commit is contained in:
parent
17f54e4c3d
commit
59f3434672
2
putty.h
2
putty.h
@ -304,7 +304,7 @@ typedef struct {
|
|||||||
char bell_wavefile[FILENAME_MAX];
|
char bell_wavefile[FILENAME_MAX];
|
||||||
int scrollbar;
|
int scrollbar;
|
||||||
int scrollbar_in_fullscreen;
|
int scrollbar_in_fullscreen;
|
||||||
enum { RESIZE_TERM, RESIZE_DISABLED, RESIZE_FONT } resize_action;
|
enum { RESIZE_TERM, RESIZE_DISABLED, RESIZE_FONT, RESIZE_EITHER } resize_action;
|
||||||
int bce;
|
int bce;
|
||||||
int blinktext;
|
int blinktext;
|
||||||
int win_name_always;
|
int win_name_always;
|
||||||
|
14
windlg.c
14
windlg.c
@ -358,6 +358,7 @@ enum { IDCX_ABOUT =
|
|||||||
IDC_RESIZETERM,
|
IDC_RESIZETERM,
|
||||||
IDC_RESIZEFONT,
|
IDC_RESIZEFONT,
|
||||||
IDC_RESIZENONE,
|
IDC_RESIZENONE,
|
||||||
|
IDC_RESIZEEITHER,
|
||||||
IDC_SCROLLBAR,
|
IDC_SCROLLBAR,
|
||||||
IDC_SCROLLBARFULLSCREEN,
|
IDC_SCROLLBARFULLSCREEN,
|
||||||
IDC_CLOSEWARN,
|
IDC_CLOSEWARN,
|
||||||
@ -681,9 +682,10 @@ static void init_dlg_ctrls(HWND hwnd, int keepsess)
|
|||||||
CheckDlgButton(hwnd, IDC_BLINKCUR, cfg.blink_cur);
|
CheckDlgButton(hwnd, IDC_BLINKCUR, cfg.blink_cur);
|
||||||
CheckDlgButton(hwnd, IDC_SCROLLBAR, cfg.scrollbar);
|
CheckDlgButton(hwnd, IDC_SCROLLBAR, cfg.scrollbar);
|
||||||
CheckDlgButton(hwnd, IDC_SCROLLBARFULLSCREEN, cfg.scrollbar_in_fullscreen);
|
CheckDlgButton(hwnd, IDC_SCROLLBARFULLSCREEN, cfg.scrollbar_in_fullscreen);
|
||||||
CheckRadioButton(hwnd, IDC_RESIZETERM, IDC_RESIZENONE,
|
CheckRadioButton(hwnd, IDC_RESIZETERM, IDC_RESIZEEITHER,
|
||||||
cfg.resize_action == RESIZE_TERM ? IDC_RESIZETERM :
|
cfg.resize_action == RESIZE_TERM ? IDC_RESIZETERM :
|
||||||
cfg.resize_action == RESIZE_FONT ? IDC_RESIZEFONT :
|
cfg.resize_action == RESIZE_FONT ? IDC_RESIZEFONT :
|
||||||
|
cfg.resize_action == RESIZE_EITHER ? IDC_RESIZEEITHER :
|
||||||
IDC_RESIZENONE);
|
IDC_RESIZENONE);
|
||||||
CheckRadioButton(hwnd, IDC_COEALWAYS, IDC_COENORMAL,
|
CheckRadioButton(hwnd, IDC_COEALWAYS, IDC_COENORMAL,
|
||||||
cfg.close_on_exit == COE_NORMAL ? IDC_COENORMAL :
|
cfg.close_on_exit == COE_NORMAL ? IDC_COENORMAL :
|
||||||
@ -1058,9 +1060,10 @@ static void create_controls(HWND hwnd, int dlgtype, int panel)
|
|||||||
"&Rows", IDC_ROWSSTATIC, IDC_ROWSEDIT, 50,
|
"&Rows", IDC_ROWSSTATIC, IDC_ROWSEDIT, 50,
|
||||||
"Colu&mns", IDC_COLSSTATIC, IDC_COLSEDIT, 50, NULL);
|
"Colu&mns", IDC_COLSSTATIC, IDC_COLSEDIT, 50, NULL);
|
||||||
radioline(&cp, "When window is resi&zed, change:", IDC_RESIZESTATIC,
|
radioline(&cp, "When window is resi&zed, change:", IDC_RESIZESTATIC,
|
||||||
3, "Terminal size", IDC_RESIZETERM,
|
4, "Terminal", IDC_RESIZETERM,
|
||||||
"Font size", IDC_RESIZEFONT,
|
"Font", IDC_RESIZEFONT,
|
||||||
"Forbid resize", IDC_RESIZENONE, NULL);
|
"Special", IDC_RESIZEEITHER,
|
||||||
|
"Nothing", IDC_RESIZENONE, NULL);
|
||||||
endbox(&cp);
|
endbox(&cp);
|
||||||
beginbox(&cp, "Control the scrollback in the window",
|
beginbox(&cp, "Control the scrollback in the window",
|
||||||
IDC_BOX_WINDOW2);
|
IDC_BOX_WINDOW2);
|
||||||
@ -2140,6 +2143,7 @@ static int GenericMainDlgProc(HWND hwnd, UINT msg,
|
|||||||
case IDC_RESIZETERM:
|
case IDC_RESIZETERM:
|
||||||
case IDC_RESIZEFONT:
|
case IDC_RESIZEFONT:
|
||||||
case IDC_RESIZENONE:
|
case IDC_RESIZENONE:
|
||||||
|
case IDC_RESIZEEITHER:
|
||||||
if (HIWORD(wParam) == BN_CLICKED ||
|
if (HIWORD(wParam) == BN_CLICKED ||
|
||||||
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
||||||
cfg.resize_action =
|
cfg.resize_action =
|
||||||
@ -2147,6 +2151,8 @@ static int GenericMainDlgProc(HWND hwnd, UINT msg,
|
|||||||
IDC_RESIZETERM) ? RESIZE_TERM :
|
IDC_RESIZETERM) ? RESIZE_TERM :
|
||||||
IsDlgButtonChecked(hwnd,
|
IsDlgButtonChecked(hwnd,
|
||||||
IDC_RESIZEFONT) ? RESIZE_FONT :
|
IDC_RESIZEFONT) ? RESIZE_FONT :
|
||||||
|
IsDlgButtonChecked(hwnd,
|
||||||
|
IDC_RESIZEEITHER) ? RESIZE_EITHER :
|
||||||
RESIZE_DISABLED;
|
RESIZE_DISABLED;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
101
window.c
101
window.c
@ -666,6 +666,9 @@ int WINAPI WinMain(HINSTANCE inst, HINSTANCE prev, LPSTR cmdline, int show)
|
|||||||
|
|
||||||
flash_window(1); /* maintain */
|
flash_window(1); /* maintain */
|
||||||
|
|
||||||
|
/* The messages seem unreliable; especially if we're being tricky */
|
||||||
|
has_focus = (GetForegroundWindow() == hwnd);
|
||||||
|
|
||||||
if (in_vbell)
|
if (in_vbell)
|
||||||
/* Hmm, term_update didn't want to do an update too soon ... */
|
/* Hmm, term_update didn't want to do an update too soon ... */
|
||||||
timer_id = SetTimer(hwnd, 1, 50, NULL);
|
timer_id = SetTimer(hwnd, 1, 50, NULL);
|
||||||
@ -1113,7 +1116,7 @@ void request_resize(int w, int h)
|
|||||||
|
|
||||||
/* If the window is maximized supress resizing attempts */
|
/* If the window is maximized supress resizing attempts */
|
||||||
if (IsZoomed(hwnd)) {
|
if (IsZoomed(hwnd)) {
|
||||||
if (cfg.resize_action != RESIZE_FONT)
|
if (cfg.resize_action == RESIZE_TERM)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1150,7 +1153,7 @@ void request_resize(int w, int h)
|
|||||||
|
|
||||||
term_size(h, w, cfg.savelines);
|
term_size(h, w, cfg.savelines);
|
||||||
|
|
||||||
if (cfg.resize_action != RESIZE_FONT) {
|
if (cfg.resize_action != RESIZE_FONT && !IsZoomed(hwnd)) {
|
||||||
width = extra_width + font_width * w;
|
width = extra_width + font_width * w;
|
||||||
height = extra_height + font_height * h;
|
height = extra_height + font_height * h;
|
||||||
|
|
||||||
@ -1185,6 +1188,8 @@ static void reset_window(int reinit) {
|
|||||||
win_width = cr.right - cr.left;
|
win_width = cr.right - cr.left;
|
||||||
win_height = cr.bottom - cr.top;
|
win_height = cr.bottom - cr.top;
|
||||||
|
|
||||||
|
if (cfg.resize_action == RESIZE_DISABLED) reinit = 2;
|
||||||
|
|
||||||
/* Are we being forced to reload the fonts ? */
|
/* Are we being forced to reload the fonts ? */
|
||||||
if (reinit>1) {
|
if (reinit>1) {
|
||||||
#ifdef RDB_DEBUG_PATCH
|
#ifdef RDB_DEBUG_PATCH
|
||||||
@ -1218,7 +1223,7 @@ static void reset_window(int reinit) {
|
|||||||
extra_width = wr.right - wr.left - cr.right + cr.left;
|
extra_width = wr.right - wr.left - cr.right + cr.left;
|
||||||
extra_height = wr.bottom - wr.top - cr.bottom + cr.top;
|
extra_height = wr.bottom - wr.top - cr.bottom + cr.top;
|
||||||
|
|
||||||
if (cfg.resize_action == RESIZE_FONT) {
|
if (cfg.resize_action != RESIZE_TERM) {
|
||||||
if ( font_width != win_width/cols ||
|
if ( font_width != win_width/cols ||
|
||||||
font_height != win_height/rows) {
|
font_height != win_height/rows) {
|
||||||
deinit_fonts();
|
deinit_fonts();
|
||||||
@ -1274,6 +1279,8 @@ static void reset_window(int reinit) {
|
|||||||
font_height*rows + extra_height,
|
font_height*rows + extra_height,
|
||||||
SWP_NOMOVE | SWP_NOZORDER);
|
SWP_NOMOVE | SWP_NOZORDER);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
InvalidateRect(hwnd, NULL, TRUE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1281,7 +1288,9 @@ static void reset_window(int reinit) {
|
|||||||
* window. But that may be too big for the screen which forces us
|
* window. But that may be too big for the screen which forces us
|
||||||
* to change the terminal.
|
* to change the terminal.
|
||||||
*/
|
*/
|
||||||
if ((cfg.resize_action != RESIZE_FONT && reinit==0) || reinit>0) {
|
if ((cfg.resize_action == RESIZE_TERM && reinit<=0) ||
|
||||||
|
(cfg.resize_action == RESIZE_EITHER && reinit<0) ||
|
||||||
|
reinit>0) {
|
||||||
offset_width = offset_height = cfg.window_border;
|
offset_width = offset_height = cfg.window_border;
|
||||||
extra_width = wr.right - wr.left - cr.right + cr.left + offset_width*2;
|
extra_width = wr.right - wr.left - cr.right + cr.left + offset_width*2;
|
||||||
extra_height = wr.bottom - wr.top - cr.bottom + cr.top +offset_height*2;
|
extra_height = wr.bottom - wr.top - cr.bottom + cr.top +offset_height*2;
|
||||||
@ -1298,6 +1307,19 @@ static void reset_window(int reinit) {
|
|||||||
|
|
||||||
/* Grrr too big */
|
/* Grrr too big */
|
||||||
if ( rows > height || cols > width ) {
|
if ( rows > height || cols > width ) {
|
||||||
|
if (cfg.resize_action == RESIZE_EITHER) {
|
||||||
|
/* Make the font the biggest we can */
|
||||||
|
if (cols > width)
|
||||||
|
font_width = (ss.right - ss.left - extra_width)/cols;
|
||||||
|
if (rows > height)
|
||||||
|
font_height = (ss.bottom - ss.top - extra_height)/rows;
|
||||||
|
|
||||||
|
deinit_fonts();
|
||||||
|
init_fonts(font_width, font_height);
|
||||||
|
|
||||||
|
width = (ss.right - ss.left - extra_width) / font_width;
|
||||||
|
height = (ss.bottom - ss.top - extra_height) / font_height;
|
||||||
|
} else {
|
||||||
if ( height > rows ) height = rows;
|
if ( height > rows ) height = rows;
|
||||||
if ( width > cols ) width = cols;
|
if ( width > cols ) width = cols;
|
||||||
term_size(height, width, cfg.savelines);
|
term_size(height, width, cfg.savelines);
|
||||||
@ -1306,6 +1328,7 @@ static void reset_window(int reinit) {
|
|||||||
height, width));
|
height, width));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SetWindowPos(hwnd, NULL, 0, 0,
|
SetWindowPos(hwnd, NULL, 0, 0,
|
||||||
font_width*cols + extra_width,
|
font_width*cols + extra_width,
|
||||||
@ -1569,7 +1592,8 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
if (cfg.height != prev_cfg.height ||
|
if (cfg.height != prev_cfg.height ||
|
||||||
cfg.width != prev_cfg.width ||
|
cfg.width != prev_cfg.width ||
|
||||||
cfg.savelines != prev_cfg.savelines ||
|
cfg.savelines != prev_cfg.savelines ||
|
||||||
cfg.resize_action != RESIZE_TERM)
|
cfg.resize_action == RESIZE_FONT ||
|
||||||
|
cfg.resize_action == RESIZE_DISABLED)
|
||||||
term_size(cfg.height, cfg.width, cfg.savelines);
|
term_size(cfg.height, cfg.width, cfg.savelines);
|
||||||
|
|
||||||
/* Enable or disable the scroll bar, etc */
|
/* Enable or disable the scroll bar, etc */
|
||||||
@ -1641,8 +1665,9 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
cfg.fontcharset != prev_cfg.fontcharset ||
|
cfg.fontcharset != prev_cfg.fontcharset ||
|
||||||
cfg.vtmode != prev_cfg.vtmode ||
|
cfg.vtmode != prev_cfg.vtmode ||
|
||||||
cfg.bold_colour != prev_cfg.bold_colour ||
|
cfg.bold_colour != prev_cfg.bold_colour ||
|
||||||
(cfg.resize_action != RESIZE_FONT &&
|
cfg.resize_action == RESIZE_DISABLED ||
|
||||||
prev_cfg.resize_action == RESIZE_FONT))
|
cfg.resize_action == RESIZE_EITHER ||
|
||||||
|
(cfg.resize_action != prev_cfg.resize_action))
|
||||||
init_lvl = 2;
|
init_lvl = 2;
|
||||||
|
|
||||||
InvalidateRect(hwnd, NULL, TRUE);
|
InvalidateRect(hwnd, NULL, TRUE);
|
||||||
@ -1962,6 +1987,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
term_update();
|
term_update();
|
||||||
break;
|
break;
|
||||||
case WM_KILLFOCUS:
|
case WM_KILLFOCUS:
|
||||||
|
if (full_screen) flip_full_screen();
|
||||||
show_mouseptr(1);
|
show_mouseptr(1);
|
||||||
has_focus = FALSE;
|
has_focus = FALSE;
|
||||||
DestroyCaret();
|
DestroyCaret();
|
||||||
@ -1993,22 +2019,26 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
* 1) Keep the sizetip uptodate
|
* 1) Keep the sizetip uptodate
|
||||||
* 2) Make sure the window size is _stepped_ in units of the font size.
|
* 2) Make sure the window size is _stepped_ in units of the font size.
|
||||||
*/
|
*/
|
||||||
if (cfg.resize_action == RESIZE_TERM && !alt_pressed) {
|
if (cfg.resize_action != RESIZE_FONT && !alt_pressed) {
|
||||||
int width, height, w, h, ew, eh;
|
int width, height, w, h, ew, eh;
|
||||||
LPRECT r = (LPRECT) lParam;
|
LPRECT r = (LPRECT) lParam;
|
||||||
|
|
||||||
if ( !need_backend_resize &&
|
if ( !need_backend_resize && cfg.resize_action == RESIZE_EITHER &&
|
||||||
(cfg.height != rows || cfg.width != cols )) {
|
(cfg.height != rows || cfg.width != cols )) {
|
||||||
/*
|
/*
|
||||||
* Great! It seems the host has been changing the terminal
|
* Great! It seems that both the terminal size and the
|
||||||
* size, well the user is now grabbing so this is probably
|
* font size have been changed and the user is now dragging.
|
||||||
* the least confusing solution in the long run even though
|
*
|
||||||
* it a is suprise. Unfortunatly the only way to prevent
|
* It will now be difficult to get back to the configured
|
||||||
* this seems to be to let the host change the window size
|
* font size!
|
||||||
* and as that's a user option we're still right back here.
|
*
|
||||||
*/
|
* This would be easier but it seems to be too confusing.
|
||||||
|
|
||||||
term_size(cfg.height, cfg.width, cfg.savelines);
|
term_size(cfg.height, cfg.width, cfg.savelines);
|
||||||
reset_window(2);
|
reset_window(2);
|
||||||
|
*/
|
||||||
|
cfg.height=rows; cfg.width=cols;
|
||||||
|
|
||||||
InvalidateRect(hwnd, NULL, TRUE);
|
InvalidateRect(hwnd, NULL, TRUE);
|
||||||
need_backend_resize = TRUE;
|
need_backend_resize = TRUE;
|
||||||
}
|
}
|
||||||
@ -2084,11 +2114,9 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
"...",
|
"...",
|
||||||
LOWORD(lParam), HIWORD(lParam)));
|
LOWORD(lParam), HIWORD(lParam)));
|
||||||
#endif
|
#endif
|
||||||
if (wParam == SIZE_MINIMIZED) {
|
if (wParam == SIZE_MINIMIZED)
|
||||||
SetWindowText(hwnd,
|
SetWindowText(hwnd,
|
||||||
cfg.win_name_always ? window_name : icon_name);
|
cfg.win_name_always ? window_name : icon_name);
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (wParam == SIZE_RESTORED || wParam == SIZE_MAXIMIZED)
|
if (wParam == SIZE_RESTORED || wParam == SIZE_MAXIMIZED)
|
||||||
SetWindowText(hwnd, window_name);
|
SetWindowText(hwnd, window_name);
|
||||||
|
|
||||||
@ -2103,11 +2131,11 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
height = HIWORD(lParam);
|
height = HIWORD(lParam);
|
||||||
|
|
||||||
if (!resizing) {
|
if (!resizing) {
|
||||||
if (wParam == SIZE_MAXIMIZED) {
|
if (wParam == SIZE_MAXIMIZED && !was_zoomed) {
|
||||||
was_zoomed = 1;
|
was_zoomed = 1;
|
||||||
prev_rows = rows;
|
prev_rows = rows;
|
||||||
prev_cols = cols;
|
prev_cols = cols;
|
||||||
if (cfg.resize_action != RESIZE_FONT) {
|
if (cfg.resize_action == RESIZE_TERM) {
|
||||||
w = width / font_width;
|
w = width / font_width;
|
||||||
if (w < 1) w = 1;
|
if (w < 1) w = 1;
|
||||||
h = height / font_height;
|
h = height / font_height;
|
||||||
@ -2118,8 +2146,11 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
reset_window(0);
|
reset_window(0);
|
||||||
} else if (wParam == SIZE_RESTORED && was_zoomed) {
|
} else if (wParam == SIZE_RESTORED && was_zoomed) {
|
||||||
was_zoomed = 0;
|
was_zoomed = 0;
|
||||||
if (cfg.resize_action != RESIZE_FONT)
|
if (cfg.resize_action == RESIZE_TERM)
|
||||||
term_size(prev_rows, prev_cols, cfg.savelines);
|
term_size(prev_rows, prev_cols, cfg.savelines);
|
||||||
|
if (cfg.resize_action != RESIZE_FONT)
|
||||||
|
reset_window(2);
|
||||||
|
else
|
||||||
reset_window(0);
|
reset_window(0);
|
||||||
}
|
}
|
||||||
/* This is an unexpected resize, these will normally happen
|
/* This is an unexpected resize, these will normally happen
|
||||||
@ -2137,7 +2168,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
|
|||||||
* down the connection during an NT opaque drag.)
|
* down the connection during an NT opaque drag.)
|
||||||
*/
|
*/
|
||||||
if (resizing) {
|
if (resizing) {
|
||||||
if (cfg.resize_action == RESIZE_TERM && !alt_pressed) {
|
if (cfg.resize_action != RESIZE_FONT && !alt_pressed) {
|
||||||
need_backend_resize = TRUE;
|
need_backend_resize = TRUE;
|
||||||
w = (width-cfg.window_border*2) / font_width;
|
w = (width-cfg.window_border*2) / font_width;
|
||||||
if (w < 1) w = 1;
|
if (w < 1) w = 1;
|
||||||
@ -3011,6 +3042,7 @@ static int TranslateKey(UINT message, WPARAM wParam, LPARAM lParam,
|
|||||||
}
|
}
|
||||||
if (left_alt && wParam == VK_RETURN && cfg.fullscreenonaltenter &&
|
if (left_alt && wParam == VK_RETURN && cfg.fullscreenonaltenter &&
|
||||||
(cfg.resize_action != RESIZE_DISABLED)) {
|
(cfg.resize_action != RESIZE_DISABLED)) {
|
||||||
|
if ((HIWORD(lParam) & (KF_UP | KF_REPEAT)) != KF_REPEAT)
|
||||||
flip_full_screen();
|
flip_full_screen();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -3578,7 +3610,8 @@ void set_sbar(int total, int start, int page)
|
|||||||
{
|
{
|
||||||
SCROLLINFO si;
|
SCROLLINFO si;
|
||||||
|
|
||||||
if (!cfg.scrollbar)
|
if ((full_screen && !cfg.scrollbar_in_fullscreen) ||
|
||||||
|
(!full_screen && !cfg.scrollbar))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
si.cbSize = sizeof(si);
|
si.cbSize = sizeof(si);
|
||||||
@ -4042,32 +4075,36 @@ static void flip_full_screen(void)
|
|||||||
SetWindowPlacement(hwnd, &wp);
|
SetWindowPlacement(hwnd, &wp);
|
||||||
}
|
}
|
||||||
|
|
||||||
style = GetWindowLong(hwnd, GWL_STYLE) & ~WS_CAPTION;
|
style = GetWindowLong(hwnd, GWL_STYLE) & ~(WS_CAPTION|WS_THICKFRAME);
|
||||||
style &= ~WS_VSCROLL;
|
style &= ~WS_VSCROLL;
|
||||||
if (cfg.scrollbar_in_fullscreen)
|
if (cfg.scrollbar_in_fullscreen)
|
||||||
style |= WS_VSCROLL;
|
style |= WS_VSCROLL;
|
||||||
SetWindowLong(hwnd, GWL_STYLE, style);
|
SetWindowLong(hwnd, GWL_STYLE, style);
|
||||||
|
|
||||||
/* This seems to be needed otherwize explorer doesn't notice
|
/* Some versions of explorer get confused and don't take
|
||||||
* we want to go fullscreen and it's bar is still visible
|
* notice of us going fullscreen, so go topmost too.
|
||||||
*/
|
*/
|
||||||
SetWindowPos(hwnd, NULL, 0, 0, 0, 0,
|
SetWindowPos(hwnd, HWND_TOPMOST, 0, 0, 0, 0,
|
||||||
SWP_NOACTIVATE | SWP_NOCOPYBITS |
|
SWP_NOACTIVATE | SWP_NOCOPYBITS |
|
||||||
SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER |
|
SWP_NOMOVE | SWP_NOSIZE |
|
||||||
SWP_FRAMECHANGED);
|
SWP_FRAMECHANGED);
|
||||||
|
|
||||||
wp.showCmd = SW_SHOWMAXIMIZED;
|
wp.showCmd = SW_SHOWMAXIMIZED;
|
||||||
SetWindowPlacement(hwnd, &wp);
|
SetWindowPlacement(hwnd, &wp);
|
||||||
} else {
|
} else {
|
||||||
style = GetWindowLong(hwnd, GWL_STYLE) | WS_CAPTION;
|
style = GetWindowLong(hwnd, GWL_STYLE) | WS_CAPTION;
|
||||||
|
if (cfg.resize_action != RESIZE_DISABLED)
|
||||||
|
style |= WS_THICKFRAME;
|
||||||
style &= ~WS_VSCROLL;
|
style &= ~WS_VSCROLL;
|
||||||
if (cfg.scrollbar)
|
if (cfg.scrollbar)
|
||||||
style |= WS_VSCROLL;
|
style |= WS_VSCROLL;
|
||||||
SetWindowLong(hwnd, GWL_STYLE, style);
|
SetWindowLong(hwnd, GWL_STYLE, style);
|
||||||
|
|
||||||
/* Don't need to do a SetWindowPos as the resize will force a
|
SetWindowPos(hwnd, HWND_NOTOPMOST, 0, 0, 0, 0,
|
||||||
* full redraw.
|
SWP_NOACTIVATE | SWP_NOCOPYBITS |
|
||||||
*/
|
SWP_NOMOVE | SWP_NOSIZE |
|
||||||
|
SWP_FRAMECHANGED);
|
||||||
|
|
||||||
wp.showCmd = SW_SHOWNORMAL;
|
wp.showCmd = SW_SHOWNORMAL;
|
||||||
SetWindowPlacement(hwnd, &wp);
|
SetWindowPlacement(hwnd, &wp);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user