CComboBox::SetDroppedWidth
コンボ ボックスのリスト ボックスに設定できる最小幅をピクセル単位で設定します。
int SetDroppedWidth(
UINT nWidth
);
パラメーター
- nWidth
コンボ ボックスのリスト ボックスに設定できる最小幅をピクセル単位で指定します。
戻り値
正常終了した場合は新しく設定したリスト ボックスの幅を返します。それ以外の場合は CB_ERR を返します。
解説
この関数は、CBS_DROPDOWN または CBS_DROPDOWNLIST スタイルのコンボ ボックスだけに適用されます。
既定では、ドロップダウン リスト ボックスに設定できる最小幅は 0 です。 コンボ ボックスのリスト ボックスが表示されるとき、リスト ボックスの幅は、設定できる最小幅かコンボ ボックスの幅のいずれか大きい方になります。
使用例
// Find the longest string in the combo box.
CString str;
CSize sz;
int dx = 0;
TEXTMETRIC tm;
CDC* pDC = m_pComboBox->GetDC();
CFont* pFont = m_pComboBox->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_pComboBox->GetCount(); i++)
{
m_pComboBox->GetLBText(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_pComboBox->ReleaseDC(pDC);
// Adjust the width for the vertical scroll bar and the left and right border.
dx += ::GetSystemMetrics(SM_CXVSCROLL) + 2*::GetSystemMetrics(SM_CXEDGE);
// Set the width of the list box so that every item is completely visible.
m_pComboBox->SetDroppedWidth(dx);
必要条件
**ヘッダー:**afxwin.h