- Reduce the number of messages being passed to itself by using the
internal routines. - Fix problem in _SetIconSpacing found by recent change. - Add initial support for correct icon sizing. - A few extra traces.
This commit is contained in:
parent
5f5bdd4a94
commit
027034e221
|
@ -288,6 +288,8 @@ static void ListView_UpdateLargeItemLabelRect (HWND hwnd, const LISTVIEW_INFO* i
|
||||||
static LRESULT LISTVIEW_GetColumnT(HWND, INT, LPLVCOLUMNW, BOOL);
|
static LRESULT LISTVIEW_GetColumnT(HWND, INT, LPLVCOLUMNW, BOOL);
|
||||||
static LRESULT LISTVIEW_VScroll(HWND hwnd, INT nScrollCode, SHORT nCurrentPos, HWND hScrollWnd);
|
static LRESULT LISTVIEW_VScroll(HWND hwnd, INT nScrollCode, SHORT nCurrentPos, HWND hScrollWnd);
|
||||||
static LRESULT LISTVIEW_HScroll(HWND hwnd, INT nScrollCode, SHORT nCurrentPos, HWND hScrollWnd);
|
static LRESULT LISTVIEW_HScroll(HWND hwnd, INT nScrollCode, SHORT nCurrentPos, HWND hScrollWnd);
|
||||||
|
static INT LISTVIEW_GetTopIndex(HWND hwnd);
|
||||||
|
static BOOL LISTVIEW_EnsureVisible(HWND hwnd, INT nItem, BOOL bPartial);
|
||||||
|
|
||||||
/******** Defines that LISTVIEW_ProcessLetterKeys uses ****************/
|
/******** Defines that LISTVIEW_ProcessLetterKeys uses ****************/
|
||||||
#define KEY_DELAY 450
|
#define KEY_DELAY 450
|
||||||
|
@ -553,6 +555,9 @@ static void LISTVIEW_DumpListview(LISTVIEW_INFO *iP, INT line)
|
||||||
TRACE("listview %08x at line %d, himlNor=%p, himlSml=%p, himlState=%p, Focused=%d, Hot=%d, exStyle=0x%08lx\n",
|
TRACE("listview %08x at line %d, himlNor=%p, himlSml=%p, himlState=%p, Focused=%d, Hot=%d, exStyle=0x%08lx\n",
|
||||||
iP->hwndSelf, line, iP->himlNormal, iP->himlSmall, iP->himlState,
|
iP->hwndSelf, line, iP->himlNormal, iP->himlSmall, iP->himlState,
|
||||||
iP->nFocusedItem, iP->nHotItem, iP->dwExStyle);
|
iP->nFocusedItem, iP->nHotItem, iP->dwExStyle);
|
||||||
|
TRACE("listview %08x at line %d, ntmH=%d, icSz.cx=%ld, icSz.cy=%ld, icSp.cx=%ld, icSp.cy=%ld\n",
|
||||||
|
iP->hwndSelf, line, iP->ntmHeight, iP->iconSize.cx, iP->iconSize.cy,
|
||||||
|
iP->iconSpacing.cx, iP->iconSpacing.cy);
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL
|
static BOOL
|
||||||
|
@ -2123,16 +2128,16 @@ static BOOL LISTVIEW_SetItemFocus(HWND hwnd, INT nItem)
|
||||||
infoPtr->nFocusedItem = -1;
|
infoPtr->nFocusedItem = -1;
|
||||||
ZeroMemory(&lvItem, sizeof(lvItem));
|
ZeroMemory(&lvItem, sizeof(lvItem));
|
||||||
lvItem.stateMask = LVIS_FOCUSED;
|
lvItem.stateMask = LVIS_FOCUSED;
|
||||||
ListView_SetItemState(hwnd, oldFocus, &lvItem);
|
LISTVIEW_SetItemState(hwnd, oldFocus, &lvItem);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
lvItem.state = LVIS_FOCUSED;
|
lvItem.state = LVIS_FOCUSED;
|
||||||
lvItem.stateMask = LVIS_FOCUSED;
|
lvItem.stateMask = LVIS_FOCUSED;
|
||||||
ListView_SetItemState(hwnd, nItem, &lvItem);
|
LISTVIEW_SetItemState(hwnd, nItem, &lvItem);
|
||||||
|
|
||||||
infoPtr->nFocusedItem = nItem;
|
infoPtr->nFocusedItem = nItem;
|
||||||
ListView_EnsureVisible(hwnd, nItem, FALSE);
|
LISTVIEW_EnsureVisible(hwnd, nItem, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
return bResult;
|
return bResult;
|
||||||
|
@ -2156,13 +2161,13 @@ static VOID LISTVIEW_SetSelection(HWND hwnd, INT nItem)
|
||||||
|
|
||||||
ZeroMemory(&lvItem, sizeof(lvItem));
|
ZeroMemory(&lvItem, sizeof(lvItem));
|
||||||
lvItem.stateMask = LVIS_FOCUSED;
|
lvItem.stateMask = LVIS_FOCUSED;
|
||||||
ListView_SetItemState(hwnd, infoPtr->nFocusedItem, &lvItem);
|
LISTVIEW_SetItemState(hwnd, infoPtr->nFocusedItem, &lvItem);
|
||||||
|
|
||||||
LISTVIEW_RemoveAllSelections(hwnd);
|
LISTVIEW_RemoveAllSelections(hwnd);
|
||||||
|
|
||||||
lvItem.state = LVIS_FOCUSED|LVIS_SELECTED;
|
lvItem.state = LVIS_FOCUSED|LVIS_SELECTED;
|
||||||
lvItem.stateMask = LVIS_FOCUSED|LVIS_SELECTED;
|
lvItem.stateMask = LVIS_FOCUSED|LVIS_SELECTED;
|
||||||
ListView_SetItemState(hwnd, nItem, &lvItem);
|
LISTVIEW_SetItemState(hwnd, nItem, &lvItem);
|
||||||
|
|
||||||
infoPtr->nFocusedItem = nItem;
|
infoPtr->nFocusedItem = nItem;
|
||||||
infoPtr->nSelectionMark = nItem;
|
infoPtr->nSelectionMark = nItem;
|
||||||
|
@ -2312,7 +2317,7 @@ static LRESULT LISTVIEW_MouseSelection(HWND hwnd, POINT pt)
|
||||||
LONG lStyle = GetWindowLongW(hwnd, GWL_STYLE);
|
LONG lStyle = GetWindowLongW(hwnd, GWL_STYLE);
|
||||||
UINT uView = lStyle & LVS_TYPEMASK;
|
UINT uView = lStyle & LVS_TYPEMASK;
|
||||||
|
|
||||||
topindex = ListView_GetTopIndex(hwnd);
|
topindex = LISTVIEW_GetTopIndex(hwnd);
|
||||||
if (uView == LVS_REPORT)
|
if (uView == LVS_REPORT)
|
||||||
{
|
{
|
||||||
bottomindex = topindex + LISTVIEW_GetCountPerColumn(hwnd) + 1;
|
bottomindex = topindex + LISTVIEW_GetCountPerColumn(hwnd) + 1;
|
||||||
|
@ -3287,7 +3292,7 @@ static VOID LISTVIEW_DrawItem(HWND hwnd, HDC hdc, INT nItem, RECT rcItem, BOOL F
|
||||||
nMixMode = SetROP2(hdc, R2_COPYPEN);
|
nMixMode = SetROP2(hdc, R2_COPYPEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
nLabelWidth = ListView_GetStringWidthW(hwnd, lvItem.pszText);
|
nLabelWidth = LISTVIEW_GetStringWidthT(hwnd, lvItem.pszText, TRUE);
|
||||||
if (rcItem.left + nLabelWidth < rcItem.right)
|
if (rcItem.left + nLabelWidth < rcItem.right)
|
||||||
{
|
{
|
||||||
if (!FullSelect)
|
if (!FullSelect)
|
||||||
|
@ -5772,7 +5777,7 @@ static LRESULT LISTVIEW_GetItemRect(HWND hwnd, INT nItem, LPRECT lprc)
|
||||||
switch(lprc->left)
|
switch(lprc->left)
|
||||||
{
|
{
|
||||||
case LVIR_ICON:
|
case LVIR_ICON:
|
||||||
if (!ListView_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
if (!LISTVIEW_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
||||||
if (uView == LVS_ICON)
|
if (uView == LVS_ICON)
|
||||||
{
|
{
|
||||||
if (infoPtr->himlNormal != NULL)
|
if (infoPtr->himlNormal != NULL)
|
||||||
|
@ -5826,7 +5831,7 @@ static LRESULT LISTVIEW_GetItemRect(HWND hwnd, INT nItem, LPRECT lprc)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LVIR_LABEL:
|
case LVIR_LABEL:
|
||||||
if (!ListView_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
if (!LISTVIEW_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
||||||
if (uView == LVS_ICON)
|
if (uView == LVS_ICON)
|
||||||
{
|
{
|
||||||
if (infoPtr->himlNormal != NULL)
|
if (infoPtr->himlNormal != NULL)
|
||||||
|
@ -6024,7 +6029,7 @@ static LRESULT LISTVIEW_GetItemRect(HWND hwnd, INT nItem, LPRECT lprc)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LVIR_SELECTBOUNDS:
|
case LVIR_SELECTBOUNDS:
|
||||||
if (!ListView_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
if (!LISTVIEW_GetItemPosition(hwnd, nItem, &ptItem)) break;
|
||||||
if (uView == LVS_ICON)
|
if (uView == LVS_ICON)
|
||||||
{
|
{
|
||||||
if (infoPtr->himlNormal != NULL)
|
if (infoPtr->himlNormal != NULL)
|
||||||
|
@ -6174,7 +6179,7 @@ static INT LISTVIEW_GetLabelWidth(HWND hwnd, INT nItem)
|
||||||
lvItem.cchTextMax = DISP_TEXT_SIZE;
|
lvItem.cchTextMax = DISP_TEXT_SIZE;
|
||||||
lvItem.pszText = szDispText;
|
lvItem.pszText = szDispText;
|
||||||
if (LISTVIEW_GetItemW(hwnd, &lvItem, TRUE))
|
if (LISTVIEW_GetItemW(hwnd, &lvItem, TRUE))
|
||||||
nLabelWidth = ListView_GetStringWidthW(hwnd, lvItem.pszText);
|
nLabelWidth = LISTVIEW_GetStringWidthT(hwnd, lvItem.pszText, TRUE);
|
||||||
|
|
||||||
return nLabelWidth;
|
return nLabelWidth;
|
||||||
}
|
}
|
||||||
|
@ -6466,6 +6471,9 @@ static LRESULT LISTVIEW_GetOrigin(HWND hwnd, LPPOINT lpptOrigin)
|
||||||
}
|
}
|
||||||
|
|
||||||
bResult = TRUE;
|
bResult = TRUE;
|
||||||
|
|
||||||
|
TRACE("(hwnd=%x, pt=(%ld,%ld))\n", hwnd, lpptOrigin->x, lpptOrigin->y);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return bResult;
|
return bResult;
|
||||||
|
@ -6607,7 +6615,7 @@ static INT LISTVIEW_SuperHitTestItem(HWND hwnd, LPLV_INTHIT lpInt, BOOL subitem)
|
||||||
|
|
||||||
TRACE("(hwnd=%x, x=%ld, y=%ld)\n", hwnd, lpInt->ht.pt.x, lpInt->ht.pt.y);
|
TRACE("(hwnd=%x, x=%ld, y=%ld)\n", hwnd, lpInt->ht.pt.x, lpInt->ht.pt.y);
|
||||||
|
|
||||||
topindex = ListView_GetTopIndex(hwnd);
|
topindex = LISTVIEW_GetTopIndex(hwnd);
|
||||||
if (uView == LVS_REPORT)
|
if (uView == LVS_REPORT)
|
||||||
{
|
{
|
||||||
bottomindex = topindex + LISTVIEW_GetCountPerColumn(hwnd) + 1;
|
bottomindex = topindex + LISTVIEW_GetCountPerColumn(hwnd) + 1;
|
||||||
|
@ -7674,15 +7682,18 @@ static LRESULT LISTVIEW_SetIconSpacing(HWND hwnd, DWORD spacing)
|
||||||
else
|
else
|
||||||
{ /* if 0 then compute height */
|
{ /* if 0 then compute height */
|
||||||
if (uView == LVS_ICON)
|
if (uView == LVS_ICON)
|
||||||
infoPtr->iconSpacing.cy = infoPtr->iconSize.cy + infoPtr->ntmHeight
|
infoPtr->iconSpacing.cy = infoPtr->iconSize.cy + 2 * infoPtr->ntmHeight
|
||||||
+ ICON_BOTTOM_PADDING + ICON_TOP_PADDING + LABEL_VERT_OFFSET;
|
+ ICON_BOTTOM_PADDING + ICON_TOP_PADDING + LABEL_VERT_OFFSET;
|
||||||
/* FIXME. I don't think so; I think it is based on twice the ntmHeight */
|
/* FIXME. I don't think so; I think it is based on twice the ntmHeight */
|
||||||
else /* FIXME: unknown computation for non LVS_ICON - this is a guess */
|
else /* FIXME: unknown computation for non LVS_ICON - this is a guess */
|
||||||
infoPtr->iconSpacing.cy = LISTVIEW_GetItemHeight(hwnd);
|
infoPtr->iconSpacing.cy = LISTVIEW_GetItemHeight(hwnd);
|
||||||
}
|
}
|
||||||
|
|
||||||
TRACE("old=(%d,%d), new=(%ld,%ld)\n", LOWORD(oldspacing), HIWORD(oldspacing),
|
TRACE("old=(%d,%d), new=(%ld,%ld), iconSize=(%ld,%ld), ntmH=%d\n",
|
||||||
infoPtr->iconSpacing.cx, infoPtr->iconSpacing.cy);
|
LOWORD(oldspacing), HIWORD(oldspacing),
|
||||||
|
infoPtr->iconSpacing.cx, infoPtr->iconSpacing.cy,
|
||||||
|
infoPtr->iconSize.cx, infoPtr->iconSize.cy,
|
||||||
|
infoPtr->ntmHeight);
|
||||||
|
|
||||||
/* these depend on the iconSpacing */
|
/* these depend on the iconSpacing */
|
||||||
infoPtr->nItemWidth = LISTVIEW_GetItemWidth(hwnd);
|
infoPtr->nItemWidth = LISTVIEW_GetItemWidth(hwnd);
|
||||||
|
@ -7720,6 +7731,8 @@ static HIMAGELIST LISTVIEW_SetImageList(HWND hwnd, INT nType, HIMAGELIST himl)
|
||||||
{
|
{
|
||||||
INT cx, cy;
|
INT cx, cy;
|
||||||
ImageList_GetIconSize(himl, &cx, &cy);
|
ImageList_GetIconSize(himl, &cx, &cy);
|
||||||
|
TRACE("icon old size=(%ld,%ld), new size=(%d,%d)\n",
|
||||||
|
infoPtr->iconSize.cx, infoPtr->iconSize.cy, cx, cy);
|
||||||
infoPtr->iconSize.cx = cx;
|
infoPtr->iconSize.cx = cx;
|
||||||
infoPtr->iconSize.cy = cy;
|
infoPtr->iconSize.cy = cy;
|
||||||
LISTVIEW_SetIconSpacing(hwnd,0);
|
LISTVIEW_SetIconSpacing(hwnd,0);
|
||||||
|
@ -7943,10 +7956,10 @@ static LRESULT LISTVIEW_SetItemState(HWND hwnd, INT nItem, LPLVITEMW lpLVItem)
|
||||||
{
|
{
|
||||||
/* apply to all items */
|
/* apply to all items */
|
||||||
for (lvItem.iItem = 0; lvItem.iItem < GETITEMCOUNT(infoPtr); lvItem.iItem++)
|
for (lvItem.iItem = 0; lvItem.iItem < GETITEMCOUNT(infoPtr); lvItem.iItem++)
|
||||||
if (!ListView_SetItemW(hwnd, &lvItem)) bResult = FALSE;
|
if (!LISTVIEW_SetItemT(hwnd, &lvItem, TRUE)) bResult = FALSE;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
bResult = ListView_SetItemW(hwnd, &lvItem);
|
bResult = LISTVIEW_SetItemT(hwnd, &lvItem, TRUE);
|
||||||
|
|
||||||
return bResult;
|
return bResult;
|
||||||
}
|
}
|
||||||
|
@ -8915,7 +8928,7 @@ static LRESULT LISTVIEW_LButtonDown(HWND hwnd, WORD wKey, WORD wPosX,
|
||||||
{
|
{
|
||||||
if (lStyle & LVS_SINGLESEL)
|
if (lStyle & LVS_SINGLESEL)
|
||||||
{
|
{
|
||||||
if ((ListView_GetItemState(hwnd, nItem, LVIS_SELECTED) & LVIS_SELECTED)
|
if ((LISTVIEW_GetItemState(hwnd, nItem, LVIS_SELECTED) & LVIS_SELECTED)
|
||||||
&& infoPtr->nEditLabelItem == -1)
|
&& infoPtr->nEditLabelItem == -1)
|
||||||
infoPtr->nEditLabelItem = nItem;
|
infoPtr->nEditLabelItem = nItem;
|
||||||
else
|
else
|
||||||
|
@ -8941,7 +8954,7 @@ static LRESULT LISTVIEW_LButtonDown(HWND hwnd, WORD wKey, WORD wPosX,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
BOOL was_selected =
|
BOOL was_selected =
|
||||||
(ListView_GetItemState(hwnd, nItem, LVIS_SELECTED) & LVIS_SELECTED);
|
(LISTVIEW_GetItemState(hwnd, nItem, LVIS_SELECTED) & LVIS_SELECTED);
|
||||||
|
|
||||||
/* set selection (clears other pre-existing selections) */
|
/* set selection (clears other pre-existing selections) */
|
||||||
LISTVIEW_SetSelection(hwnd, nItem);
|
LISTVIEW_SetSelection(hwnd, nItem);
|
||||||
|
@ -9600,9 +9613,28 @@ static INT LISTVIEW_StyleChanged(HWND hwnd, WPARAM wStyleType,
|
||||||
|
|
||||||
if (uNewView == LVS_ICON)
|
if (uNewView == LVS_ICON)
|
||||||
{
|
{
|
||||||
/* FIXME: should get icon size from imagelist - mjm */
|
INT oldcx, oldcy;
|
||||||
|
|
||||||
|
/* First readjust the iconSize and if necessary the iconSpacing */
|
||||||
|
oldcx = infoPtr->iconSize.cx;
|
||||||
|
oldcy = infoPtr->iconSize.cy;
|
||||||
infoPtr->iconSize.cx = GetSystemMetrics(SM_CXICON);
|
infoPtr->iconSize.cx = GetSystemMetrics(SM_CXICON);
|
||||||
infoPtr->iconSize.cy = GetSystemMetrics(SM_CYICON);
|
infoPtr->iconSize.cy = GetSystemMetrics(SM_CYICON);
|
||||||
|
if (infoPtr->himlNormal != NULL)
|
||||||
|
{
|
||||||
|
INT cx, cy;
|
||||||
|
ImageList_GetIconSize(infoPtr->himlNormal, &cx, &cy);
|
||||||
|
infoPtr->iconSize.cx = cx;
|
||||||
|
infoPtr->iconSize.cy = cy;
|
||||||
|
}
|
||||||
|
if ((infoPtr->iconSize.cx != oldcx) || (infoPtr->iconSize.cy != oldcy))
|
||||||
|
{
|
||||||
|
TRACE("icon old size=(%d,%d), new size=(%ld,%ld)\n",
|
||||||
|
oldcx, oldcy, infoPtr->iconSize.cx, infoPtr->iconSize.cy);
|
||||||
|
LISTVIEW_SetIconSpacing(hwnd,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Now update the full item width and height */
|
||||||
infoPtr->nItemWidth = LISTVIEW_GetItemWidth(hwnd);
|
infoPtr->nItemWidth = LISTVIEW_GetItemWidth(hwnd);
|
||||||
infoPtr->nItemHeight = LISTVIEW_GetItemHeight(hwnd);
|
infoPtr->nItemHeight = LISTVIEW_GetItemHeight(hwnd);
|
||||||
if (lpss->styleNew & LVS_ALIGNLEFT)
|
if (lpss->styleNew & LVS_ALIGNLEFT)
|
||||||
|
|
Loading…
Reference in New Issue