CComboBox::CompareItem
Appelé par l'infrastructure pour déterminer la position relative d'un nouvel élément dans la partie zone de liste d'une zone de liste déroulante owner-draw triée.
virtual int CompareItem(
LPCOMPAREITEMSTRUCT lpCompareItemStruct
);
Paramètres
- lpCompareItemStruct
Un long pointeur vers une structure de COMPAREITEMSTRUCT .
Valeur de retour
Indique la position relative des deux éléments décrits dans la structure d' COMPAREITEMSTRUCT . Il peut s'agir de l'une des valeurs suivantes :
Valeur |
Signification |
---|---|
– 1 |
Trie de priorité 1 avant l'élément 2. |
0 |
Tri de priorité 1 et 2 du point les mêmes. |
1 |
Trie du point 1 après le point 2. |
Consultez CWnd::OnCompareItem pour une description d' COMPAREITEMSTRUCT.
Notes
Par défaut, cette fonction membre ne fait rien. Si vous créez une zone de liste déroulante owner-draw avec le style de LBS_SORT , vous devez substituer cette fonction membre pour aider l'infrastructure du tri de nouveaux éléments ajoutés à la zone de liste.
Exemple
// 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;
}
Configuration requise
Header: afxwin.h