Как настроить ширину столбца в соответствии с шириной самой длинной строки в 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]);
    }

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

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);
} 

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

Другие вопросы по тегам