/* * System metrics functions * * Copyright 1994 Alexandre Julliard * */ #include #include "winbase.h" #include "winuser.h" #include "gdi.h" #include "monitor.h" #include "options.h" #include "sysmetrics.h" #include "tweak.h" short sysMetrics[SM_CMETRICS+1]; /*********************************************************************** * SYSMETRICS_Init * * Initialisation of the system metrics array. * * Differences in return values between 3.1 and 95 apps under Win95 (FIXME ?): * SM_CXVSCROLL x+1 x * SM_CYHSCROLL x+1 x * SM_CXDLGFRAME x-1 x * SM_CYDLGFRAME x-1 x * SM_CYCAPTION x+1 x * SM_CYMENU x-1 x * SM_CYFULLSCREEN x-1 x * * (collides with TWEAK_WineLook sometimes, * so changing anything might be difficult) */ void SYSMETRICS_Init(void) { sysMetrics[SM_CXCURSOR] = 32; sysMetrics[SM_CYCURSOR] = 32; sysMetrics[SM_CXSCREEN] = MONITOR_GetWidth(&MONITOR_PrimaryMonitor); sysMetrics[SM_CYSCREEN] = MONITOR_GetHeight(&MONITOR_PrimaryMonitor); sysMetrics[SM_CXVSCROLL] = PROFILE_GetWineIniInt("Tweak.Layout", "ScrollBarWidth", 16) + 1; sysMetrics[SM_CYHSCROLL] = sysMetrics[SM_CXVSCROLL]; if (TWEAK_WineLook > WIN31_LOOK) sysMetrics[SM_CYCAPTION] = PROFILE_GetWineIniInt("Tweak.Layout", "CaptionHeight", 19); else sysMetrics[SM_CYCAPTION] = 2 + PROFILE_GetWineIniInt("Tweak.Layout", "CaptionHeight", 18); sysMetrics[SM_CXBORDER] = 1; sysMetrics[SM_CYBORDER] = sysMetrics[SM_CXBORDER]; sysMetrics[SM_CXDLGFRAME] = PROFILE_GetWineIniInt("Tweak.Layout", "DialogFrameWidth", (TWEAK_WineLook > WIN31_LOOK) ? 3 : 4); sysMetrics[SM_CYDLGFRAME] = sysMetrics[SM_CXDLGFRAME]; sysMetrics[SM_CYVTHUMB] = sysMetrics[SM_CXVSCROLL] - 1; sysMetrics[SM_CXHTHUMB] = sysMetrics[SM_CYVTHUMB]; sysMetrics[SM_CXICON] = 32; sysMetrics[SM_CYICON] = 32; if (TWEAK_WineLook > WIN31_LOOK) sysMetrics[SM_CYMENU] = PROFILE_GetWineIniInt("Tweak.Layout", "MenuHeight", 19); else sysMetrics[SM_CYMENU] = PROFILE_GetWineIniInt("Tweak.Layout", "MenuHeight", 18); sysMetrics[SM_CXFULLSCREEN] = sysMetrics[SM_CXSCREEN]; sysMetrics[SM_CYFULLSCREEN] = sysMetrics[SM_CYSCREEN] - sysMetrics[SM_CYCAPTION]; sysMetrics[SM_CYKANJIWINDOW] = 0; sysMetrics[SM_MOUSEPRESENT] = 1; sysMetrics[SM_CYVSCROLL] = sysMetrics[SM_CYVTHUMB]; sysMetrics[SM_CXHSCROLL] = sysMetrics[SM_CXHTHUMB]; sysMetrics[SM_DEBUG] = 0; /* FIXME: The following should look for the registry key to see if the buttons should be swapped. */ sysMetrics[SM_SWAPBUTTON] = 0; sysMetrics[SM_RESERVED1] = 0; sysMetrics[SM_RESERVED2] = 0; sysMetrics[SM_RESERVED3] = 0; sysMetrics[SM_RESERVED4] = 0; /* FIXME: The following two are calculated, but how? */ sysMetrics[SM_CXMIN] = (TWEAK_WineLook > WIN31_LOOK) ? 112 : 100; sysMetrics[SM_CYMIN] = (TWEAK_WineLook > WIN31_LOOK) ? 27 : 28; sysMetrics[SM_CXSIZE] = sysMetrics[SM_CYCAPTION] - 2; sysMetrics[SM_CYSIZE] = sysMetrics[SM_CXSIZE]; sysMetrics[SM_CXFRAME] = GetProfileInt32A("Windows", "BorderWidth", 4); sysMetrics[SM_CYFRAME] = sysMetrics[SM_CXFRAME]; sysMetrics[SM_CXMINTRACK] = sysMetrics[SM_CXMIN]; sysMetrics[SM_CYMINTRACK] = sysMetrics[SM_CYMIN]; sysMetrics[SM_CXDOUBLECLK] = (GetProfileInt32A("Windows", "DoubleClickWidth", 4) + 1) & ~1; sysMetrics[SM_CYDOUBLECLK] = (GetProfileInt32A("Windows","DoubleClickHeight", 4) + 1) & ~1; sysMetrics[SM_CXICONSPACING] = GetProfileInt32A("Desktop","IconSpacing", 75); sysMetrics[SM_CYICONSPACING] = GetProfileInt32A("Desktop", "IconVerticalSpacing", 75); sysMetrics[SM_MENUDROPALIGNMENT] = GetProfileInt32A("Windows", "MenuDropAlignment", 0); sysMetrics[SM_PENWINDOWS] = 0; sysMetrics[SM_DBCSENABLED] = 0; /* FIXME: Need to query X for the following */ sysMetrics[SM_CMOUSEBUTTONS] = 3; sysMetrics[SM_SECURE] = 0; sysMetrics[SM_CXEDGE] = sysMetrics[SM_CXBORDER] + 1; sysMetrics[SM_CYEDGE] = sysMetrics[SM_CXEDGE]; sysMetrics[SM_CXMINSPACING] = 160; sysMetrics[SM_CYMINSPACING] = 24; sysMetrics[SM_CXSMICON] = sysMetrics[SM_CYSIZE] - (sysMetrics[SM_CYSIZE] % 2) - 2; sysMetrics[SM_CYSMICON] = sysMetrics[SM_CXSMICON]; sysMetrics[SM_CYSMCAPTION] = 16; sysMetrics[SM_CXSMSIZE] = 15; sysMetrics[SM_CYSMSIZE] = sysMetrics[SM_CXSMSIZE]; sysMetrics[SM_CXMENUSIZE] = sysMetrics[SM_CYMENU]; sysMetrics[SM_CYMENUSIZE] = sysMetrics[SM_CXMENUSIZE]; /* FIXME: What do these mean? */ sysMetrics[SM_ARRANGE] = 8; sysMetrics[SM_CXMINIMIZED] = 160; sysMetrics[SM_CYMINIMIZED] = 24; /* FIXME: How do I calculate these? */ sysMetrics[SM_CXMAXTRACK] = sysMetrics[SM_CXSCREEN] + 4 + 2 * sysMetrics[SM_CXFRAME]; sysMetrics[SM_CYMAXTRACK] = sysMetrics[SM_CYSCREEN] + 4 + 2 * sysMetrics[SM_CYFRAME]; sysMetrics[SM_CXMAXIMIZED] = sysMetrics[SM_CXSCREEN] + 2 * sysMetrics[SM_CXFRAME]; sysMetrics[SM_CYMAXIMIZED] = sysMetrics[SM_CYSCREEN] - 45; sysMetrics[SM_NETWORK] = 3; /* For the following: 0 = ok, 1 = failsafe, 2 = failsafe + network */ sysMetrics[SM_CLEANBOOT] = 0; sysMetrics[SM_CXDRAG] = 2; sysMetrics[SM_CYDRAG] = 2; sysMetrics[SM_SHOWSOUNDS] = 0; sysMetrics[SM_CXMENUCHECK] = 2; sysMetrics[SM_CYMENUCHECK] = 2; /* FIXME: Should check the type of processor for the following */ sysMetrics[SM_SLOWMACHINE] = 0; /* FIXME: Should perform a check */ sysMetrics[SM_MIDEASTENABLED] = 0; sysMetrics[SM_MOUSEWHEELPRESENT] = 0; sysMetrics[SM_CXVIRTUALSCREEN] = sysMetrics[SM_CXSCREEN]; sysMetrics[SM_CYVIRTUALSCREEN] = sysMetrics[SM_CYSCREEN]; sysMetrics[SM_XVIRTUALSCREEN] = 0; sysMetrics[SM_YVIRTUALSCREEN] = 0; sysMetrics[SM_CMONITORS] = 1; sysMetrics[SM_SAMEDISPLAYFORMAT] = 1; sysMetrics[SM_CMETRICS] = SM_CMETRICS; } /*********************************************************************** * GetSystemMetrics16 (USER.179) */ INT16 WINAPI GetSystemMetrics16( INT16 index ) { return (INT16)GetSystemMetrics32(index); } /*********************************************************************** * GetSystemMetrics32 (USER32.292) */ INT32 WINAPI GetSystemMetrics32( INT32 index ) { if ((index < 0) || (index > SM_CMETRICS)) return 0; else return sysMetrics[index]; }