CComboBox::CompareItem
Chamado pela estrutura para determinar a posição relativa de um item novo na lista-parte de caixa de uma caixa de combinação classificada proprietário-draw.
virtual int CompareItem(
LPCOMPAREITEMSTRUCT lpCompareItemStruct
);
Parâmetros
- lpCompareItemStruct
Um ponteiro para um longoCOMPAREITEMSTRUCT estrutura.
Valor de retorno
Indica a posição relativa dos dois itens descrito o COMPAREITEMSTRUCT estrutura. Ele pode ser qualquer um dos seguintes valores:
Valor |
Significado |
---|---|
– 1 |
Classifica o item 1 antes de item 2. |
0 |
O item 1 e item 2 classificar o mesmo. |
1 |
Classifica o item 1 após o item 2. |
See CWnd::OnCompareItem para obter uma descrição de COMPAREITEMSTRUCT.
Comentários
Por padrão, essa função de membro não faz nada.Se você criar uma caixa de combinação do desenho proprietário com o LBS_SORT estilo, você deve substituir essa função de membro para ajudar a estrutura de classificação de novos itens adicionados à caixa de listagem.
Exemplo
// 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;
}
Requisitos
Cabeçalho: afxwin.h