Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

340 lines
8.6 KiB

#include "cabinet.h"
#include "traycmn.h"
#include "trayitem.h"
#include "shellapi.h"
//
// CTrayItem members...
//
DWORD CTrayItem::_GetStateFlag(ICONSTATEFLAG sf)
{
DWORD dwFlag = 0;
switch (sf)
{
case TIF_HIDDEN:
dwFlag = NIS_HIDDEN;
break;
case TIF_DEMOTED:
dwFlag = NISP_DEMOTED;
break;
case TIF_STARTUPICON:
dwFlag = NISP_STARTUPICON;
break;
case TIF_SHARED:
dwFlag = NIS_SHAREDICON;
break;
case TIF_SHAREDICONSOURCE:
dwFlag = NISP_SHAREDICONSOURCE;
break;
case TIF_ONCEVISIBLE:
dwFlag = NISP_ONCEVISIBLE;
break;
case TIF_ITEMCLICKED:
dwFlag = NISP_ITEMCLICKED;
break;
case TIF_ITEMSAMEICONMODIFY:
dwFlag = NISP_ITEMSAMEICONMODIFY;
break;
}
ASSERT(dwFlag);
return dwFlag;
}
void CTrayItem::_SetIconState(ICONSTATEFLAG sf, BOOL bSet)
{
DWORD dwFlag = _GetStateFlag(sf);
ASSERT(dwFlag);
if (bSet)
dwState |= (dwFlag & 0xFFFFFFFF);
else
dwState &= ~dwFlag;
}
BOOL CTrayItem::_CheckIconState(ICONSTATEFLAG sf)
{
DWORD dwFlag = _GetStateFlag(sf);
ASSERT(dwFlag);
return ((dwState & dwFlag) != 0);
}
//
// CTrayItemManager members
//
CTrayItem * CTrayItemManager::GetItemData(INT_PTR i, BOOL byIndex, HWND hwndToolbar)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.lParam = 0;
tbbi.dwMask = TBIF_LPARAM;
if (byIndex)
tbbi.dwMask |= TBIF_BYINDEX;
SendMessage(hwndToolbar, TB_GETBUTTONINFO, i, (LPARAM)&tbbi);
return (CTrayItem *)(void *)tbbi.lParam;
}
INT_PTR CTrayItemManager::FindItemAssociatedWithGuid(GUID guidItemToCheck)
{
if (guidItemToCheck == GUID_NULL)
return -1;
for (INT_PTR i = GetItemCount()-1; i >= 0; i--)
{
CTrayItem * pti = GetItemDataByIndex(i);
if (pti && pti->IsGuidItemValid() && IsEqualGUID(pti->guidItem, guidItemToCheck))
return i;
}
return -1;
}
INT_PTR CTrayItemManager::FindItemAssociatedWithTimer(UINT_PTR uIconDemoteTimerID)
{
for (INT_PTR i = GetItemCount()-1; i >= 0; i--)
{
CTrayItem * pti = GetItemDataByIndex(i);
if (pti && pti->uIconDemoteTimerID == uIconDemoteTimerID)
return i;
}
return -1;
}
INT_PTR CTrayItemManager::FindItemAssociatedWithHwndUid(HWND hwnd, UINT uID)
{
for (INT_PTR i = GetItemCount() - 1; i >= 0; --i)
{
CTrayItem * pti = GetItemDataByIndex(i);
if (pti && (pti->hWnd == hwnd) && (pti->uID == uID))
{
return i;
}
}
return -1;
}
// Decides if there are as many "TNUP_AUTOMATIC" demoted items in the tray, above the
// threshold that the user has specified...
// Returns TRUE if there is any TNUP_DEMOTED item in the list...
BOOL CTrayItemManager::DemotedItemsPresent(int nMinDemotedItemsThreshold)
{
ASSERT(nMinDemotedItemsThreshold >= 0);
INT_PTR cIcons = 0;
INT_PTR nItems = SendMessage(m_hwndToolbar, TB_BUTTONCOUNT, 0, 0L);
for (INT_PTR i = 0; i < nItems; i++)
{
CTrayItem * pti = GetItemDataByIndex(i);
ASSERT(pti);
// If the item is set to ALWAYS HIDE, then it must be shown in demoted state...
if (pti->dwUserPref == TNUP_DEMOTED)
{
return TRUE;
}
// If the item is demoted, then only if there are enough demoted items must
// they all be shown in demoted state...
else if (pti->IsDemoted())
{
cIcons++;
if (cIcons >= nMinDemotedItemsThreshold)
return TRUE;
}
}
return FALSE;
}
// Works irrespective of whether AutoTray is enabled or not...
INT_PTR CTrayItemManager::_GetItemCountHelper(int nItemFlag, int nItemCountThreshold)
{
INT_PTR cIcons = 0;
INT_PTR nItems = SendMessage(m_hwndToolbar, TB_BUTTONCOUNT, 0, 0L);
switch(nItemFlag)
{
case GIC_ALL:
cIcons = nItems;
break;
case GIC_PROMOTED:
case GIC_DEMOTED:
for (INT_PTR i = nItems-1; i>= 0; i--)
{
CTrayItem * pti = GetItemDataByIndex(i);
if (nItemFlag == GIC_PROMOTED)
{
if (pti && !pti->IsDemoted() && !pti->IsHidden())
cIcons ++;
}
else
{
if (pti && pti->IsDemoted())
cIcons++;
}
if (nItemCountThreshold != -1 && cIcons >= nItemCountThreshold)
break;
}
break;
}
return cIcons;
}
void CTrayItemManager::SetTBBtnImage(INT_PTR iIndex, int iImage)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_IMAGE | TBIF_BYINDEX;
tbbi.iImage = iImage;
SendMessage(m_hwndToolbar, TB_SETBUTTONINFO, iIndex, (LPARAM)&tbbi);
}
int CTrayItemManager::GetTBBtnImage(INT_PTR iIndex, BOOL fByIndex /* = TRUE */)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_IMAGE;
if (fByIndex)
tbbi.dwMask |= TBIF_BYINDEX;
SendMessage(m_hwndToolbar, TB_GETBUTTONINFO, iIndex, (LPARAM)&tbbi);
return tbbi.iImage;
}
BOOL CTrayItemManager::SetTBBtnStateHelper(INT_PTR iIndex, BYTE fsState, BOOL_PTR bSet)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_STATE | TBIF_BYINDEX;
// Get the original state of the button
SendMessage(m_hwndToolbar, TB_GETBUTTONINFO, iIndex, (LPARAM)&tbbi);
// Or the new state to the original state
BYTE fsStateOld = tbbi.fsState;
if (bSet)
tbbi.fsState |= fsState;
else
tbbi.fsState &= ~fsState;
if (tbbi.fsState ^ fsStateOld)
{
SendMessage(m_hwndToolbar, TB_SETBUTTONINFO, iIndex, (LPARAM)&tbbi);
return TRUE;
}
return FALSE;
}
void CTrayItemManager::SetTBBtnText(INT_PTR iIndex, LPTSTR pszText)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_TEXT | TBIF_BYINDEX;
tbbi.pszText = pszText;
tbbi.cchText = -1;
SendMessage(m_hwndToolbar, TB_SETBUTTONINFO, iIndex, (LPARAM)&tbbi);
}
/*
BOOL CTrayItemManager::GetTBBtnText(INT_PTR iIndex, TCHAR * pszBuffer, INT nBufferLength)
{
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_BYINDEX | TBIF_TEXT;
tbbi.pszText = pszBuffer;
tbbi.cchText = nBufferLength;
if (SendMessage(m_hwndToolbar, TB_GETBUTTONINFO, iIndex, (LPARAM)&tbbi) != -1)
return TRUE;
pszBuffer[0] = TEXT('\0');
return FALSE;
}
*/
int CTrayItemManager::FindImageIndex(HICON hIcon, BOOL fSetAsSharedSource)
{
INT_PTR i;
INT_PTR iCount = GetItemCount();
for (i = 0; i < iCount; i++)
{
CTrayItem * pti = GetItemDataByIndex(i);
if (pti && pti->hIcon == hIcon)
{
// if we're supposed to mark this as a shared icon source and its not itself a shared icon
// target, mark it now. this is to allow us to recognize when the source icon changes and
// that we can know that we need to find other indicies and update them too.
if (fSetAsSharedSource && !pti->IsIconShared())
pti->SetSharedIconSource(TRUE);
return GetTBBtnImage(i);
}
}
return -1;
}
// TO DO szText can be replaced by pti->szIconText
BOOL CTrayItemManager::GetTrayItem(INT_PTR nIndex, CNotificationItem * pni, BOOL * pbStat)
{
if (nIndex < 0 || nIndex >= GetItemCount())
{
*pbStat = FALSE;
return FALSE;
}
ASSERT(pni->hIcon == NULL); // else we're going to leak it
TBBUTTONINFO tbbi;
tbbi.cbSize = sizeof(tbbi);
tbbi.dwMask = TBIF_BYINDEX | TBIF_IMAGE | TBIF_LPARAM | TBIF_TEXT;
TCHAR szText[80] = {0};
tbbi.pszText = szText;
tbbi.cchText = ARRAYSIZE(szText);
if (SendMessage(m_hwndToolbar, TB_GETBUTTONINFO, nIndex, (LPARAM)&tbbi) != -1)
{
CTrayItem * pti = (CTrayItem *)tbbi.lParam;
// don't expose the NIS_HIDDEN icons
if (pti && !pti->IsHidden())
{
pni->hWnd = pti->hWnd;
pni->uID = pti->uID;
pni->hIcon = ImageList_GetIcon(m_himlIcons, tbbi.iImage, ILD_NORMAL);
pni->dwUserPref = pti->dwUserPref;
pni->SetExeName(pti->szExeName);
pni->SetIconText(szText);
memcpy(&(pni->guidItem), &(pti->guidItem), sizeof(pti->guidItem));
*pbStat = TRUE;
return TRUE;
}
}
*pbStat = FALSE;
return TRUE;
}