ITaskbarList3::ThumbBarSetImageList 方法 (shobjidl_core.h)
指定一个图像列表,该列表包含嵌入任务栏按钮浮出控件中窗口的缩略图图像中的工具栏的按钮图像。
语法
HRESULT ThumbBarSetImageList(
[in] HWND hwnd,
[in] HIMAGELIST himl
);
参数
[in] hwnd
类型:HWND
其缩略图表示形式包含要更新的工具栏的窗口的句柄。 此句柄必须属于调用进程。
[in] himl
类型: HIMAGELIST
包含工具栏中使用的所有按钮图像的图像列表的句柄。
返回值
类型: HRESULT
如果该方法成功,则返回 S_OK。 否则,将返回 HRESULT 错误代码。
注解
应用程序必须提供以下按钮图像:
- 处于其默认活动状态的按钮。
- 适合用于高 dpi (每英寸点数) 显示器的图像。
图像必须为 32 位,尺寸必须为 GetSystemMetrics (SM_CXICON) x GetSystemMetrics (SM_CYICON) 。 工具栏本身为按钮的单击、禁用和悬停状态提供视觉对象。
示例
以下示例演示如何创建包含两个按钮的缩略图工具栏,这些按钮的图像来自图像列表。
HRESULT AddThumbarButtons(HWND hwnd, HIMAGELIST himl, HIMAGELIST himlHot)
{
// Define an array of two buttons. These buttons provide images through an
// image list and also provide tooltips.
DWORD dwMask = THB_BITMAP | THB_TOOLTIP | THB_FLAGS;
THUMBBUTON thbButtons[2];
thbButtons[0].dwMask = dwMask;
thbButtons[0].iId = 0;
thbButtons[0].iBitmap = 0;
thbButtons[0].pszTip = TEXT("Button 1");
thbButtons[0].dwFlags = THBF_DISMISSONCLICK;
dwMask = THB_BITMAP | THB_TOOLTIP;
thbButtons[1].dwMask = dwMask;
thbButtons[1].iId = 1;
thbButtons[1].iBitmap = 1;
thbButtons[1].pszTip = TEXT("Button 2");
// Create an instance of ITaskbarList3
ITaskBarList3 *ptbl;
HRESULT hr = CoCreateInstance(CLSID_TaskbarList,
NULL,
CLSCTX_INPROC_SERVER,
IID_PPV_ARGS(&ptbl);
if (SUCCEEDED(hr))
{
// Declare the image list that contains the button images.
hr = ptbl->ThumbBarSetImageList(hwnd, himl);
if (SUCCEEDED(hr))
{
// Attach the toolbar to the thumbnail.
hr = ptbl->ThumbBarAddButtons(hwnd, ARRAYSIZE(thbButtons), &thbButtons);
}
ptbl->Release();
}
return hr;
}
要求
最低受支持的客户端 | Windows 7 [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2008 R2 [仅限桌面应用] |
目标平台 | Windows |
标头 | shobjidl_core.h (包括 Shobjidl.h) |
Library | Explorerframe.lib |
DLL | Explorerframe.dll |
另请参阅
ITaskbarList3::ThumbBarAddButtons