Aracılığıyla paylaş


CComboBox::CompareItem

Göre sıralanmış sahibi tarafından çizilen birleşik giriş kutusunun liste kutusu bölümünde yeni bir öğenin göreceli konumunu belirlemek için çerçeve olarak adlandırılır.

virtual int CompareItem(
   LPCOMPAREITEMSTRUCT lpCompareItemStruct 
);

Parametreler

Dönüş Değeri

Açıklanan iki öğenin göreceli konumunu gösterir COMPAREITEMSTRUCT yapısı.Aşağıdaki değerlerden biri olabilir:

Value

Anlam

– 1

Madde 1 2 maddesi önce sıralar.

0

Madde 1 ve 2 maddesi aynı sıralama.

1

Madde 1 2 öğesinden sonra sıralar.

Bkz: CWnd::OnCompareItem bir açıklaması için COMPAREITEMSTRUCT.

Notlar

Varsayılan olarak, bu üye işlev hiçbir şey yapmaz.Bir sahibi tarafından çizilen birleşik giriş kutusu oluşturmak lbs_sort stili, size gereken geçersiz framework yeni liste kutusuna eklenen öğeleri sıralama içinde size yardımcı olmak için bu üye işlevi.

Örnek

// CMyComboBox is my owner-drawn combo box derived from CComboBox. This 
// example compares two items using strcmp to sort items in reverse 
// alphabetical order. 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);
//
int CMyComboBox::CompareItem(LPCOMPAREITEMSTRUCT lpCompareItemStruct)
{
   int iComp = 0;
   ASSERT(lpCompareItemStruct->CtlType == ODT_COMBOBOX);
   LPCTSTR lpszText1 = (LPCTSTR) lpCompareItemStruct->itemData1;
   ASSERT(lpszText1 != NULL);
   LPCTSTR lpszText2 = (LPCTSTR) lpCompareItemStruct->itemData2;
   ASSERT(lpszText2 != NULL);

   if (NULL != lpszText1 && NULL != lpszText2)
   {
      iComp = _tcscmp(lpszText2, lpszText1);    
   }

   return iComp;
}

Gereksinimler

Başlık: afxwin.h

Ayrıca bkz.

Başvuru

CComboBox sınıfı

Hiyerarşi grafik

WM_COMPAREITEM

CComboBox::DrawItem

CComboBox::MeasureItem

CComboBox::DeleteItem