Как настроить ширину столбца в соответствии с шириной самой длинной строки в CListCtrl?

Я стараюсь:

tstring subItemText;
CDC* pDc = GetListCtrl().GetDC();
for (int row = GetItemCount() - 1; row >= 0; --row)
{
subItemText = _T("");
for (int col = 0; col < NumCol; ++col)
{
subItemText = this->GetSubItemString( GetItemData(row), col);
CSize sz;
// get length of the string in logical units, by default 1 unit == 1 pixel, type of font is accounted
sz = pDc->GetOutputTextExtent(subItemText.c_str());
if (static_cast<int>(sz.cx) > ColWidth[col])
ColWidth[col] = sz.cx;
}
}
GetListCtrl().ReleaseDC (pDc);
for (int col = 0; col < NumCol; ++col)
{
SetColumnWidth(col, ColWidth[col]);
}

В результате ширина столбца на 20/30% больше, чем одна из самых больших строк в этом столбце.
Я хочу, чтобы ширина столбца была равна ширине строки с максимальной длиной.

Заранее спасибо!

2

Решение

Вероятно, это потому, что вы не выбрали правильный шрифт в контексте устройства. Попробуй это :

    tstring subItemText;
CDC* pDc = GetListCtrl().GetDC();

CFont *normalfont = GetListCtrl().GetFont() ;
CFont *oldfont = pDc->SelectObject(normalfont) ;

for (int row = GetItemCount() - 1; row >= 0; --row)
{
subItemText = _T("");
for (int col = 0; col < NumCol; ++col)
{
subItemText = this->GetSubItemString( GetItemData(row), col);
CSize sz;
// get length of the string in logical units, by default 1 unit == 1 pixel, type of font is accounted
sz = pDc->GetOutputTextExtent(subItemText.c_str());
if (static_cast<int>(sz.cx) > ColWidth[col])
ColWidth[col] = sz.cx;
}
}

pDc->SelectObject(oldfont) ;

GetListCtrl().ReleaseDC (pDc);
for (int col = 0; col < NumCol; ++col)
{
SetColumnWidth(col, ColWidth[col]);
}
3

Другие решения

Я думаю, что все, что вам нужно, это:

SetColumnWidth(col, LVSCW_AUTOSIZE);

В своих проектах я получаю свой собственный класс от CListCtrl и используйте следующую функцию

void CMyListCtrl::AutoSizeColumnWidths()
{
// size column widths to content
int nNumColumns = GetHeaderCtrl()->GetItemCount();

// for all columns ...
for (int i = 0; i < nColumnCount; i++)
{
// find max of content vs header
SetColumnWidth(i, LVSCW_AUTOSIZE);
int nColumnWidth = GetColumnWidth(i);
SetColumnWidth(i, LVSCW_AUTOSIZE_USEHEADER);
int nHeaderWidth = GetColumnWidth(i);

// set width to max
SetColumnWidth(i, max(nColumnWidth, nHeaderWidth));
}
SetRedraw(TRUE);
}

Это гарантирует, что столбцы без содержимого по-прежнему будут иметь размер в соответствии с текстом заголовка.

2