CComboBox::CompareItem
Вызываемый платформой, чтобы указать относительное положение нового элемента списка в поле со списком сортированного рисования владельцем.
virtual int CompareItem(
LPCOMPAREITEMSTRUCT lpCompareItemStruct
);
Параметры
- lpCompareItemStruct
Длинный указатель на структуру COMPAREITEMSTRUCT.
Возвращаемое значение
Указывает относительное положение 2 элементов, описанных в структуре COMPAREITEMSTRUCT. Он может быть любой из следующих значений:
Значение |
Значение |
---|---|
– 1 |
Сортировки элемента 1 перед элементом 2. |
0 |
Сортировка элементов 1 и элемента 2. |
1 |
Сортировки элемента 1 после элемента 2. |
См. раздел CWnd::OnCompareItem описание COMPAREITEMSTRUCT.
Заметки
По умолчанию этот функция-член не выполняет никаких действий. При создании поля со списком рисования владельцем в стиле LBS_SORT, следует переопределить этот функцию-член, помогающий платформы в сортировке новые элементы, добавленные в список.
Пример
// 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;
}
Требования
Header: afxwin.h