次の方法で共有


CComboBox::MeasureItem

オーナー描画スタイルでコンボ ボックスが作成されたときに、フレームワークによって呼び出されます。

virtual void MeasureItem(
   LPMEASUREITEMSTRUCT lpMeasureItemStruct 
);

パラメーター

  • lpMeasureItemStruct
    MEASUREITEMSTRUCT 構造体への long 型のポインター。

解説

既定では、このメンバー関数は何も実行しません。 このメンバー関数をオーバーライドし、MEASUREITEMSTRUCT 構造体に情報を設定すると、コンボ ボックスのリスト ボックスのサイズが Windows に通知されます。 コンボ ボックスが CBS_OWNERDRAWVARIABLE スタイルで作成されている場合、フレームワークはリスト ボックスのすべての項目に対してこのメンバー関数を呼び出します。 それ以外の場合、このメンバー関数は一度だけ呼び出されます。

CWndSubclassDlgItem メンバー関数を使用して作成したオーナー描画コンボ ボックスに CBS_OWNERDRAWFIXED スタイルを適用する場合、プログラミング時に考慮する必要のある点が増えます。 詳細については、「テクニカル ノート 14: カスタム コントロール」を参照してください。

MEASUREITEMSTRUCT 構造体の詳細については、「CWnd::OnMeasureItem」を参照してください。

使用例

// CMyComboBox is my owner-drawn combo box derived from CComboBox. This 
// example measures an item and sets the height of the item to twice the 
// vertical extent of its text. The combo box control was created with 
// the following code:
//   pmyComboBox->Create(
//      WS_CHILD|WS_VISIBLE|WS_BORDER|WS_HSCROLL|WS_VSCROLL|
//      CBS_SORT|CBS_OWNERDRAWVARIABLE,
//      myRect, pParentWnd, 1);
//
void CMyComboBox::MeasureItem(LPMEASUREITEMSTRUCT lpMeasureItemStruct) 
{
   ASSERT(lpMeasureItemStruct->CtlType == ODT_COMBOBOX);

   if (lpMeasureItemStruct->itemID != (UINT) -1)
   {
      LPCTSTR lpszText = (LPCTSTR) lpMeasureItemStruct->itemData;
      ASSERT(lpszText != NULL);
      CSize   sz;
      CDC*    pDC = GetDC();

      sz = pDC->GetTextExtent(lpszText);

      ReleaseDC(pDC);

      lpMeasureItemStruct->itemHeight = 2*sz.cy;
   }
}

必要条件

**ヘッダー:**afxwin.h

参照

参照

CComboBox クラス

階層図

CComboBox::CompareItem

CComboBox::DrawItem

WM_MEASUREITEM

CComboBox::DeleteItem

その他の技術情報

CComboBox のメンバー