Windows/MFC

GetSysColor

aucd29 2013. 10. 2. 18:10

GetSysColor

The GetSysColor function retrieves the current color of the specified display element. Display elements are the parts of a window and the display that appear on the system display screen.

DWORD GetSysColor(
  int nIndex
);

Parameters

nIndex
[in] Display element whose color is to be retrieved. This parameter can be one of the following values.
Value Meaning
COLOR_3DDKSHADOW
21
Dark shadow for three-dimensional display elements.
COLOR_3DFACE
15
Face color for three-dimensional display elements and for dialog box backgrounds.
COLOR_3DHIGHLIGHT
20
Highlight color for three-dimensional display elements (for edges facing the light source.)
COLOR_3DHILIGHT
20
Highlight color for three-dimensional display elements (for edges facing the light source.)
COLOR_3DLIGHT
22
Light color for three-dimensional display elements (for edges facing the light source.)
COLOR_3DSHADOW
16
Shadow color for three-dimensional display elements (for edges facing away from the light source).
COLOR_ACTIVEBORDER
10
Active window border.
COLOR_ACTIVECAPTION
2
Active window title bar.

Specifies the left side color in the color gradient of an active window's title bar if the gradient effect is enabled.

Windows NT and Windows 95:  This remark does not apply.

COLOR_APPWORKSPACE
12
Background color of multiple document interface (MDI) applications.
COLOR_BACKGROUND
1
Desktop.
COLOR_BTNFACE
15
Face color for three-dimensional display elements and for dialog box backgrounds.
COLOR_BTNHIGHLIGHT
20
Highlight color for three-dimensional display elements (for edges facing the light source.)
COLOR_BTNHIGHLIGHT
20
Highlight color for three-dimensional display elements (for edges facing the light source.)
COLOR_BTNSHADOW
16
Shadow color for three-dimensional display elements (for edges facing away from the light source).
COLOR_BTNTEXT
18
Text on push buttons.
COLOR_CAPTIONTEXT
9
Text in caption, size box, and scroll bar arrow box.
COLOR_DESKTOP
1
Desktop.
COLOR_GRADIENTACTIVECAPTION
27
Right side color in the color gradient of an active window's title bar. COLOR_ACTIVECAPTION specifies the left side color. Use SPI_GETGRADIENTCAPTIONS with the SystemParametersInfo function to determine whether the gradient effect is enabled.
Windows NT and Windows 95:  This value is not supported.
COLOR_GRADIENTINACTIVECAPTION
28
Right side color in the color gradient of an inactive window's title bar. COLOR_INACTIVECAPTION specifies the left side color.
Windows NT and Windows 95:  This value is not supported.
COLOR_GRAYTEXT
17
Grayed (disabled) text. This color is set to 0 if the current display driver does not support a solid gray color.
COLOR_HIGHLIGHT
13
Item(s) selected in a control.
COLOR_HIGHLIGHTTEXT
14
Text of item(s) selected in a control.
COLOR_HOTLIGHT
26
Color for a hot-tracked item. Single clicking a hot-tracked item executes the item.
Windows NT and Windows 95:  This value is not supported.
COLOR_INACTIVEBORDER
11
Inactive window border.
COLOR_INACTIVECAPTION
3
Inactive window caption.

Specifies the left side color in the color gradient of an inactive window's title bar if the gradient effect is enabled.

Windows NT and Windows 95:  This remark does not apply.

COLOR_INACTIVECAPTIONTEXT
19
Color of text in an inactive caption.
COLOR_INFOBK
24
Background color for tooltip controls.
COLOR_INFOTEXT
23
Text color for tooltip controls.
COLOR_MENU
4
Menu background.
COLOR_MENUHILIGHT
29
The color used to highlight menu items when the menu appears as a flat menu (see SystemParametersInfo). The highlighted menu item is outlined with COLOR_HIGHLIGHT.
Windows 2000/NT and Windows Me/98/95:  This value is not supported.
COLOR_MENUBAR
30
The background color for the menu bar when menus appear as flat menus (see SystemParametersInfo). However, COLOR_MENU continues to specify the background color of the menu popup.
Windows 2000/NT and Windows Me/98/95:  This value is not supported.
COLOR_MENUTEXT
7
Text in menus.
COLOR_SCROLLBAR
0
Scroll bar gray area.
COLOR_WINDOW
5
Window background.
COLOR_WINDOWFRAME
6
Window frame.
COLOR_WINDOWTEXT
8
Text in windows.

Return Values

The function returns the red, green, blue (RGB) color value of the given element.

If the nIndex parameter is out of range, the return value is zero. Because zero is also a valid RGB value, you cannot use GetSysColor to determine whether a system color is supported by the current platform. Instead, use the GetSysColorBrush function, which returns NULL if the color is not supported.

Remarks

System colors for monochrome displays are usually interpreted as shades of gray.

To paint with a system color brush, an application should use GetSysColorBrush(nIndex), instead of CreateSolidBrush(GetSysColor(nIndex)), because GetSysColorBrush returns a cached brush, instead of allocating a new one.

Example Code

For an example, see Changing the Colors of Window Elements.

Requirements

Client Requires Windows XP, Windows 2000 Professional, Windows NT Workstation, Windows Me, Windows 98, or Windows 95.
Server Requires Windows Server 2003, Windows 2000 Server, or Windows NT Server.
Header

Declared in Winuser.h; include Windows.h.

Library

Link to User32.lib.

DLL Requires User32.dll.

See Also

System Information Functions, CreateSolidBrush, GetSysColorBrush, SetSysColors, SystemParametersInfo