CComboBox::CompareItem

Wywołana przez ramy do określenia położenia nowego elementu w polu listy części pola kombi sortowane rysowania przez właściciela.

virtual int CompareItem( 
   LPCOMPAREITEMSTRUCT lpCompareItemStruct  
);

Parametry

Wartość zwracana

Wskazuje położenie względne dwa elementy opisane w COMPAREITEMSTRUCT struktury.Może być dowolną z następujących wartości:

Wartość

Znaczenie

– 1

Pozycja 1 sortuje przed pkt 2.

0

Pozycja 1 i 2 pozycja sortować takie same.

1

Sortuje pozycja 1 po pkt 2.

Zobacz CWnd::OnCompareItem opis COMPAREITEMSTRUCT.

Uwagi

Domyślnie funkcja Członkowskich nie działa.Jeśli utworzyć pole kombi rysowania przez właściciela, z LBS_SORT styl, należy zastąpić tej funkcji Członkowskich ułatwiających ramach sortowania nowe elementy dodane do pola listy.

Przykład

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

Wymagania

Nagłówek: afxwin.h

Zobacz też

Informacje

Klasa CComboBox

Diagram hierarchii

WM_COMPAREITEM

CComboBox::DrawItem

CComboBox::MeasureItem

CComboBox::DeleteItem