次の方法で共有


CListBox::SetHorizontalExtent

幅を、リスト ボックスは水平にスクロールできるピクセル単位で指定します。

void SetHorizontalExtent(
   int cxExtent 
);

パラメーター

  • cxExtent
    リスト ボックスは水平にスクロールできるピクセル数) を指定します。

解説

リスト ボックスのサイズがこの値より小さい場合、水平スクロール バーが水平方向にリスト ボックスの項目をスクロールします。リスト ボックスがこの値よりも大きいように、ある場合は、水平スクロール バーが非表示になります。

SetHorizontalExtentの呼び出しに応答するには、リスト ボックスは WS_HSCROLL のスタイルで定義されている必要があります。

このメンバー関数は、複数列]ボックスの一覧で役に立ちません。複数列リスト ボックスに、SetColumnWidth のメンバー関数を呼び出します。

使用例

// Find the longest string in the list box.
CString    str;
CSize      sz;
int        dx = 0;
TEXTMETRIC tm;
CDC*       pDC = m_myListBox.GetDC();
CFont*     pFont = m_myListBox.GetFont();

// Select the listbox font, save the old font
CFont* pOldFont = pDC->SelectObject(pFont);
// Get the text metrics for avg char width
pDC->GetTextMetrics(&tm); 

for (int i = 0; i < m_myListBox.GetCount(); i++)
{
   m_myListBox.GetText(i, str);
   sz = pDC->GetTextExtent(str);

   // Add the avg width to prevent clipping
   sz.cx += tm.tmAveCharWidth;

   if (sz.cx > dx)
      dx = sz.cx;
}
// Select the old font back into the DC
pDC->SelectObject(pOldFont);
m_myListBox.ReleaseDC(pDC);

// Set the horizontal extent so every character of all strings 
// can be scrolled to.
m_myListBox.SetHorizontalExtent(dx);

必要条件

ヘッダー: afxwin.h

参照

関連項目

CListBox クラス

階層図

CListBox::GetHorizontalExtent

CListBox::SetColumnWidth

LB_SETHORIZONTALEXTENT