Partager via


CListCtrl::GetItemRect

Récupère le rectangle englobant de l'ensemble ou une partie d'un élément dans l'affichage actuel.

BOOL GetItemRect(
   int nItem,
   LPRECT lpRect,
   UINT nCode 
) const;

Paramètres

  • nItem
    L'index de l'élément dont la position doit être récupérée.

  • lpRect
    Adresse d'une structure de RECT qui accepte le rectangle englobant.

  • nCode
    Partie de l'élément de l'affichage de liste pour lequel récupérer le rectangle englobant.Elle peut être l'une de ces valeurs :

    • LVIR_BOUNDS retourne le rectangle englobant de l'élément entier, y compris l'icône et l'étiquette.

    • LVIR_ICON retourne le rectangle englobant de l'icône ou de la petite icône.

    • LVIR_LABEL retourne le rectangle englobant du texte de l'élément.

Valeur de retour

Une valeur différente de zéro si l'opération a réussi ; sinon zéro.

Exemple

// OnClick is the handler for the NM_CLICK notification
void CListCtrlDlg::OnClick(NMHDR* pNMHDR, LRESULT* pResult)
{
    UNREFERENCED_PARAMETER(pResult);

    LPNMITEMACTIVATE pia = (LPNMITEMACTIVATE)pNMHDR;

    // Get the current mouse location and convert it to client
    // coordinates.
    CPoint pos( ::GetMessagePos() ); 
    ScreenToClient(&pos);

    // Get indexes of the first and last visible items in 
    // the listview control.
    int index = m_myListCtrl.GetTopIndex();
    int last_visible_index = index + m_myListCtrl.GetCountPerPage();
    if (last_visible_index > m_myListCtrl.GetItemCount())
        last_visible_index = m_myListCtrl.GetItemCount();

    // Loop until number visible items has been reached.
    while (index <= last_visible_index)
    {
        // Get the bounding rectangle of an item. If the mouse
        // location is within the bounding rectangle of the item,
        // you know you have found the item that was being clicked.
        CRect r;
        m_myListCtrl.GetItemRect(index, &r, LVIR_BOUNDS);
        if (r.PtInRect(pia->ptAction))
        {
            UINT flag = LVIS_SELECTED | LVIS_FOCUSED;
            m_myListCtrl.SetItemState(index, flag, flag);
            break;
        }

        // Get the next item in listview control.
        index++;
    }
}

Configuration requise

Header: afxcmn.h

Voir aussi

Référence

Classe de CListCtrl

Graphique de la hiérarchie

CListCtrl::GetItemPosition

CListCtrl::SetItemPosition

CListCtrl::GetOrigin