From 830a9e8862f782da4b57d7389ea4e1a6836e2715 Mon Sep 17 00:00:00 2001 From: Dimitriy Ryazantcev Date: Fri, 6 Sep 2024 13:42:38 +0300 Subject: [PATCH 1/3] Update about-icons.md --- desktop-src/menurc/about-icons.md | 104 ++++++++---------------------- 1 file changed, 28 insertions(+), 76 deletions(-) diff --git a/desktop-src/menurc/about-icons.md b/desktop-src/menurc/about-icons.md index 3b44c336cff..1de5df641be 100644 --- a/desktop-src/menurc/about-icons.md +++ b/desktop-src/menurc/about-icons.md @@ -25,27 +25,7 @@ ms.date: 05/31/2018 # About Icons -The system uses icons throughout the user interface to represent objects such as files, folders, shortcuts, applications, and documents. The icon functions enable applications to create, load, display, arrange, animate, and destroy icons. For information on specifying icons for file types, see [**ExtractIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extracticona). - -This overview provides information on the following topics: - -- [Icon Hot Spot](#icon-hot-spot) -- [Icon Types](#icon-types) -- [Icon Sizes](#icon-sizes) - - [To change the size of the system small icon](#to-change-the-size-of-the-system-small-icon) - - [To retrieve the size of the system small icon](#to-retrieve-the-size-of-the-system-small-icon) - - [To retrieve the size of the system large icon](#to-retrieve-the-size-of-the-system-large-icon) - - [To retrieve the size of the shell small icon](#to-retrieve-the-size-of-the-shell-small-icon) - - [To change the size of the large icon](#to-change-the-size-of-the-large-icon) - - [To retrieve the size of the shell large icon](#to-retrieve-the-size-of-the-shell-large-icon) -- [Icon Creation](#icon-creation) -- [Icon Display](#icon-display) -- [Icon Destruction](#icon-destruction) -- [Icon Duplication](#icon-duplication) - -## Icon Hot Spot - -One of the pixels in an icon is designated as the [hot spot](#icon-hot-spot), which is the point the system tracks and recognizes as the position of the icon. An icon's hot spot is typically the pixel located at the center of the icon. If you use the [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect) function to create an icon, you can specify any pixel to be the hot spot. +The system uses icons throughout the user interface to represent objects such as files, folders, shortcuts, applications, and documents. The icon functions enable applications to create, load, display, arrange, animate, and destroy icons. For information on specifying icons for file types, see [**ExtractIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonw). ## Icon Types @@ -73,75 +53,56 @@ Also, starting with Windows Vista, an additional set of **standard system shell The system uses four icon sizes: -- System small -- System large -- Shell small -- Shell large -- Jumbo (starting Windows Vista) - -The *system small icon* is displayed in the window caption. - -See [Icon scaling](/windows/apps/design/style/iconography/app-icon-construction#icon-scaling) for recommendations on preferred icon sizes for your application. - -### To change the size of the system small icon - -1. From Control Panel, click **Display**, then click the **Appearance** tab. -2. Select **Caption Buttons** from the **Item** list, then set the **Size** field. - -### To retrieve the size of the system small icon - -- Call the [**GetSystemMetrics**](/windows/desktop/api/winuser/nf-winuser-getsystemmetrics) function with **SM\_CXSMICON** and **SM\_CYSMICON**. - -The *system large icon* is mainly used by applications, but it is also displayed in the Alt+Tab dialog. The [**CreateIconFromResource**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresource), [**DrawIcon**](/windows/desktop/api/Winuser/nf-winuser-drawicon), [**ExtractAssociatedIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extractassociatedicona), [**ExtractIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extracticona), [**ExtractIconEx**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonexa), and [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadicona) functions all use system large icons. The size of the system large icon is defined by the video driver, therefore it cannot be changed. +- System small (usually 16x16 pixels size) +- System large (usually 32x32 pixels size) +- Shell small (usually 16x16 pixels size) +- Shell large (usually 32x32 pixels size) +- Shell extra-large (usually 48x48 pixels size) +- **Starting Windows Vista:** Jumbo (256x256 pixels size) -### To retrieve the size of the system large icon +The *system small* icon is displayed in the window caption. +The *system large* icon is mainly used by applications, but it is also displayed in the Alt+Tab dialog. +The *shell* and *jumbo* icons are used in the Windows Explorer and the common dialogs. -- Call [**GetSystemMetrics**](/windows/desktop/api/winuser/nf-winuser-getsystemmetrics) with **SM\_CXICON** and **SM\_CYICON**. +When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexw) structure to be used in registering your window class, set the `hIcon` member to the system large icon and the `hIconSm` member to the system small icon. For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes). -The [**CreateIcon**](/windows/desktop/api/Winuser/nf-winuser-createicon), [**CreateIconFromResourceEx**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresourceex), [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect), and [**SHGetFileInfo**](/windows/win32/api/shellapi/nf-shellapi-shgetfileinfoa) functions can be used to work with icons in sizes other than system large. +As of Windows Vista, *shell small*, *shell large*, and *extra large* scale with dots per inch (dpi) if the process is [marked as dpi-aware](/windows/win32/hidpi/high-dpi-desktop-application-development-on-windows). *Jumbo* icon is fixed at 256 pixels regardless of the dpi-aware setting. -The *shell small icon* is used in the Windows Explorer and the common dialogs. Currently, this defaults to the system small size. - -### To retrieve the size of the shell small icon +See [Icon scaling](/windows/apps/design/style/iconography/app-icon-construction#icon-scaling) for recommendations on preferred icon sizes for your application. -1. Use the [SHGetFileInfo](/windows/win32/api/shellapi/nf-shellapi-shgetfileinfoa) function with `SHGFI_SHELLICONSIZE | SHGFI_SMALLICON` to retrieve a handle to the system image list. -2. Then call the [**ImageList\_GetIconSize**](/windows/win32/api/commctrl/nf-commctrl-imagelist_geticonsize) function to get the icon size. +### To retrieve the size of the system icon -The shell large icon is used on the desktop. +- Call the [**GetSystemMetrics**](/windows/desktop/api/winuser/nf-winuser-getsystemmetrics) function with `SM_CXSMICON`/`SM_CYSMICON` or `SM_CXICON`/`SM_CYICON`. -### To change the size of the large icon +The [**CreateIconFromResource**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresource), [**DrawIcon**](/windows/desktop/api/Winuser/nf-winuser-drawicon), [**ExtractAssociatedIcon**](/windows/desktop/api/shellapi/nf-shellapi-extractassociatediconw), [**ExtractIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonw), [**ExtractIconEx**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonexw), and [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadiconw) functions all use *system large* icons. -1. From Control Panel , click **Display**, then click the **Appearance** tab, -2. Select **Icon** from the **Item** list, then set the **Size** field (this size is stored in the registry, under **HKEY\_CURRENT\_USER\\Control Panel, Desktop\\WindowMetrics\\Shell Icon Size**). -3. Click the **Plus!** tab and then select the **Use Large Icons** check box. +The [**CreateIcon**](/windows/desktop/api/Winuser/nf-winuser-createicon), [**LoadImage**](/windows/win32/api/winuser/nf-winuser-loadimagew), [**CreateIconFromResourceEx**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresourceex), [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect), and [**SHGetFileInfo**](/windows/win32/api/shellapi/nf-shellapi-shgetfileinfow) functions can be used to work with icons in sizes *other than system large*. -### To retrieve the size of the shell large icon +### To retrieve the size of the shell icon -1. Use the [**SHGetFileInfo**](/windows/win32/api/shellapi/nf-shellapi-shgetfileinfoa) function with **SHGFI\_SHELLICONSIZE** to retrieve a handle to the system image list. +1. Use the [**SHGetImageList**](/windows/win32/api/shellapi/nf-shellapi-shgetimagelist) function with `SHIL_SMALL`/`SHIL_LARGE`/`SHIL_EXTRALARGE`/`SHIL_JUMBO` to retrieve a handle to the system image list. 2. Then call the [**ImageList\_GetIconSize**](/windows/win32/api/commctrl/nf-commctrl-imagelist_geticonsize) function to get the icon size. -When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexa) structure to be used in registering your window class, set the **hIcon** member to the system large icon (usually 32x32) and the **hIconSm** member to the system small icon (usually 16x16). For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes). - ## Icon Creation -Standard icons are predefined, so it is not necessary to create them. To use a standard icon, an application can obtain its handle by using the [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagea) function. An *icon handle* is a unique value of the **HICON** type that identifies a standard or custom icon. +Standard icons are predefined, so it is not necessary to create them. To use a standard icon, an application can obtain its handle by using the [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagew) function. An *icon handle* is a unique value of the **HICON** type that identifies a standard or custom icon. -To create a custom icon for an application, you would typically use a graphics application and include the [ICON Resource](./icon-resource.md) in the application's resource-definition file. At run-time, you can call [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadicona) or [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagea) to retrieve a handle to the icon. An icon resource can contain a group of images for several different display devices. **LoadIcon** and **LoadImage** automatically select the most appropriate icon from the group for the current display device. +To create a custom icon for an application, you would typically use a graphics application and include the [ICON Resource](./icon-resource.md) in the application's resource-definition file. At run-time, you can call [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadiconw) or [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagew) to retrieve a handle to the icon. An icon resource can contain a group of images for several different display devices. **LoadIcon** and **LoadImage** automatically select the most appropriate icon from the group for the current display device. -An application can also create a custom icon at run-time by using the [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect) function, which creates an icon based on the contents of an [**ICONINFO**](/windows/desktop/api/Winuser/ns-winuser-iconinfo) structure. The [**GetIconInfo**](/windows/desktop/api/Winuser/nf-winuser-geticoninfo) function fills the structure with the hot-spot coordinates and information about the bitmask bitmap and color bitmap for the icon. +An application can also create a custom icon at run-time by using the [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect) function, which creates an icon based on the contents of an [**ICONINFO**](/windows/desktop/api/Winuser/ns-winuser-iconinfo) structure. The [**GetIconInfo**](/windows/desktop/api/Winuser/nf-winuser-geticoninfo) function fills the structure with the information about the bitmask bitmap and color bitmap for the icon. -Applications should implement custom icons as resources and should use [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadicona) or [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagea), rather than create the icon at run-time. Using icon resources avoids device dependence, simplifies localization, and enables applications to share icon shapes. +Applications should implement custom icons as resources and should use [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadiconw) or [**LoadImage**](/windows/desktop/api/Winuser/nf-winuser-loadimagew), rather than create the icon at run-time. Using icon resources avoids device dependence, simplifies localization, and enables applications to share icon shapes. The [**CreateIconFromResourceEx**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresourceex) function enables an application to browse through the system's resources and create icons and cursors based on resource data. **CreateIconFromResourceEx** creates an icon based on binary resource data from other executable files or DLLs. An application must precede this function with calls to the [**LookupIconIdFromDirectoryEx**](/windows/desktop/api/Winuser/nf-winuser-lookupiconidfromdirectoryex) function and several of the resource functions. **LookupIconIdFromDirectoryEx** returns the identifier of the most appropriate icon data for the current display device. ## Icon Display -You can retrieve the image for an icon by using the [**GetIconInfo**](/windows/desktop/api/Winuser/nf-winuser-geticoninfo) function, and can draw it by using the [**DrawIconEx**](/windows/desktop/api/Winuser/nf-winuser-drawiconex) function. To draw the default image for a icon, specify the **DI\_COMPAT** flag in the call to **DrawIconEx**. If you do not specify the **DI\_COMPAT** flag, **DrawIconEx** draws the icon using the image that the user specified. +You can retrieve the image for an icon by using the [**GetIconInfo**](/windows/desktop/api/Winuser/nf-winuser-geticoninfo) function, and can draw it by using the [**DrawIconEx**](/windows/desktop/api/Winuser/nf-winuser-drawiconex) function. When the system displays an icon, it must extract the appropriate icon image from the .exe or .dll file. The system uses the following steps to select the icon image: -1. Select the **RT\_GROUP\_ICON** resource. If more than one such resource exists, the system uses the first resource listed in the resource scrip. -2. Select the appropriate **RT\_ICON** image from the **RT\_GROUP\_ICON** resource. If more than one image exists, the system uses the following criteria to choose an image: +1. Select the `RT_GROUP_ICON` resource. If more than one such resource exists, the system uses the first resource listed in the resource scrip. +2. Select the appropriate `RT_ICON` image from the `RT_GROUP_ICON` resource. If more than one image exists, the system uses the following criteria to choose an image: - The image closest in size to the requested size is chosen. - If two or more images of that size are present, the one that matches the color depth of the display is chosen. - If no images exactly match the color depth of the display, the image with the greatest color depth that does not exceed the color depth of the display is chosen. If all exceed the color depth, the one with the lowest color depth is chosen. @@ -149,18 +110,13 @@ When the system displays an icon, it must extract the appropriate icon image fro > [!Note] > The system treats all color depths of 8 or more bpp as equal. Therefore, there is no advantage of including a 16x16 256-color image and a 16x16 16-color image in the same resource—the system will simply choose the first one it encounters. When the display is in 8-bpp mode, the system will choose a 16-color icon over a 256-color icon, and will display all icons using the system default palette. -  - To display an animated icon, use a static control as shown in the following code fragment. - -``` +```cpp hIcon = LoadImage(NULL, "ico.ani", IMAGE_ICON, 0, 0, LR_LOADFROMFILE); -SendMessage( hStatic, STM_SETIMAGE, IMAGE_ICON, (LPARAM)(UINT)hIcon); +SendMessage(hStatic, STM_SETIMAGE, IMAGE_ICON, (LPARAM)(UINT)hIcon); ``` - - ## Icon Destruction When an application no longer needs an icon it created by using the [**CreateIconIndirect**](/windows/desktop/api/Winuser/nf-winuser-createiconindirect) function, it should destroy the icon. The [**DestroyIcon**](/windows/desktop/api/Winuser/nf-winuser-destroyicon) function destroys the icon handle and frees any memory used by the icon. Applications should use this function only for icons created with **CreateIconIndirect**; it is not necessary to destroy other icons. @@ -174,7 +130,3 @@ The [**CopyImage**](/windows/desktop/api/Winuser/nf-winuser-copyimage) function For information about adding, removing, or replacing icon resources in executable (.exe) files, see [Resources](resources.md). The [**DuplicateIcon**](/windows/desktop/api/Shellapi/nf-shellapi-duplicateicon) function makes an actual copy of the icon. - -  - -  From 4fbada7b63e3fa03da9b863b1ddbff651608252e Mon Sep 17 00:00:00 2001 From: Dimitriy Ryazantcev Date: Tue, 10 Sep 2024 19:13:56 +0300 Subject: [PATCH 2/3] Update about-icons.md --- desktop-src/menurc/about-icons.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/desktop-src/menurc/about-icons.md b/desktop-src/menurc/about-icons.md index 1de5df641be..dc06f314123 100644 --- a/desktop-src/menurc/about-icons.md +++ b/desktop-src/menurc/about-icons.md @@ -61,10 +61,10 @@ The system uses four icon sizes: - **Starting Windows Vista:** Jumbo (256x256 pixels size) The *system small* icon is displayed in the window caption. -The *system large* icon is mainly used by applications, but it is also displayed in the Alt+Tab dialog. +The *system large* icon is mainly used by applications, but it is also displayed in the classic Alt+Tab dialog. The *shell* and *jumbo* icons are used in the Windows Explorer and the common dialogs. -When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexw) structure to be used in registering your window class, set the `hIcon` member to the system large icon and the `hIconSm` member to the system small icon. For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes). +When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexw) structure to be used in registering your window class, set the `hIcon` member to the system large icon and the `hIconSm` member to the system small icon. For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes#class-icons). As of Windows Vista, *shell small*, *shell large*, and *extra large* scale with dots per inch (dpi) if the process is [marked as dpi-aware](/windows/win32/hidpi/high-dpi-desktop-application-development-on-windows). *Jumbo* icon is fixed at 256 pixels regardless of the dpi-aware setting. @@ -72,7 +72,7 @@ See [Icon scaling](/windows/apps/design/style/iconography/app-icon-construction# ### To retrieve the size of the system icon -- Call the [**GetSystemMetrics**](/windows/desktop/api/winuser/nf-winuser-getsystemmetrics) function with `SM_CXSMICON`/`SM_CYSMICON` or `SM_CXICON`/`SM_CYICON`. +- Call the [**GetSystemMetrics**](/windows/desktop/api/winuser/nf-winuser-getsystemmetrics) function with `SM_CXICON`/`SM_CYICON` or `SM_CXSMICON`/`SM_CYSMICON`. The [**CreateIconFromResource**](/windows/desktop/api/Winuser/nf-winuser-createiconfromresource), [**DrawIcon**](/windows/desktop/api/Winuser/nf-winuser-drawicon), [**ExtractAssociatedIcon**](/windows/desktop/api/shellapi/nf-shellapi-extractassociatediconw), [**ExtractIcon**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonw), [**ExtractIconEx**](/windows/desktop/api/Shellapi/nf-shellapi-extracticonexw), and [**LoadIcon**](/windows/desktop/api/Winuser/nf-winuser-loadiconw) functions all use *system large* icons. From 5d03394b17cdf153bb650f8ab5bb6eee0776ae0a Mon Sep 17 00:00:00 2001 From: Dimitriy Ryazantcev Date: Mon, 18 Nov 2024 15:51:38 +0200 Subject: [PATCH 3/3] Update about-icons.md --- desktop-src/menurc/about-icons.md | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/desktop-src/menurc/about-icons.md b/desktop-src/menurc/about-icons.md index dc06f314123..9f0fb3030da 100644 --- a/desktop-src/menurc/about-icons.md +++ b/desktop-src/menurc/about-icons.md @@ -51,21 +51,20 @@ Also, starting with Windows Vista, an additional set of **standard system shell ## Icon Sizes -The system uses four icon sizes: +The system uses two icon sizes: + +- System small (usually 16x16 pixels size) - is displayed in the window caption +- System large (usually 32x32 pixels size) - is mainly used by applications, but it is also displayed in the classic Alt+Tab dialog + +When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexw) structure to be used in registering your window class, set the `hIcon` member to the system large icon and the `hIconSm` member to the system small icon. For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes#class-icons). + +Windows Explorer shell and common dialogs are using four icon sizes: -- System small (usually 16x16 pixels size) -- System large (usually 32x32 pixels size) - Shell small (usually 16x16 pixels size) - Shell large (usually 32x32 pixels size) - Shell extra-large (usually 48x48 pixels size) - **Starting Windows Vista:** Jumbo (256x256 pixels size) -The *system small* icon is displayed in the window caption. -The *system large* icon is mainly used by applications, but it is also displayed in the classic Alt+Tab dialog. -The *shell* and *jumbo* icons are used in the Windows Explorer and the common dialogs. - -When filling in the [**WNDCLASSEX**](/windows/win32/api/winuser/ns-winuser-wndclassexw) structure to be used in registering your window class, set the `hIcon` member to the system large icon and the `hIconSm` member to the system small icon. For more information about class icons, see [Class Icons](/windows/desktop/winmsg/about-window-classes#class-icons). - As of Windows Vista, *shell small*, *shell large*, and *extra large* scale with dots per inch (dpi) if the process is [marked as dpi-aware](/windows/win32/hidpi/high-dpi-desktop-application-development-on-windows). *Jumbo* icon is fixed at 256 pixels regardless of the dpi-aware setting. See [Icon scaling](/windows/apps/design/style/iconography/app-icon-construction#icon-scaling) for recommendations on preferred icon sizes for your application.