Partilhar via


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

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

Consulte também

Referência

Classe CComboBox

Gráfico de hierarquia

WM_COMPAREITEM

CComboBox::DrawItem

CComboBox::MeasureItem

CComboBox::DeleteItem

Outros recursos

CComboBox membros