ListView.DrawItem ListView.DrawItem ListView.DrawItem ListView.DrawItem Event

Définition

Se produit lorsqu’un ListView est dessinée et la OwnerDraw propriété est définie sur true.Occurs when a ListView is drawn and the OwnerDraw property is set to true.

public:
 event System::Windows::Forms::DrawListViewItemEventHandler ^ DrawItem;
public event System.Windows.Forms.DrawListViewItemEventHandler DrawItem;
member this.DrawItem : System.Windows.Forms.DrawListViewItemEventHandler 
Public Custom Event DrawItem As DrawListViewItemEventHandler 

Exemples

L’exemple de code suivant fournit une implémentation d’un DrawItem Gestionnaire d’événements.The following code example provides an implementation of a DrawItem event handler. Pour obtenir un exemple complet, consultez le OwnerDraw rubrique de référence.For the complete example, see the OwnerDraw reference topic.

// Draws the backgrounds for entire ListView items.
private void listView1_DrawItem(object sender,
    DrawListViewItemEventArgs e)
{
    if ((e.State & ListViewItemStates.Selected) != 0)
    {
        // Draw the background and focus rectangle for a selected item.
        e.Graphics.FillRectangle(Brushes.Maroon, e.Bounds);
        e.DrawFocusRectangle();
    }
    else
    {
        // Draw the background for an unselected item.
        using (LinearGradientBrush brush =
            new LinearGradientBrush(e.Bounds, Color.Orange,
            Color.Maroon, LinearGradientMode.Horizontal))
        {
            e.Graphics.FillRectangle(brush, e.Bounds);
        }
    }

    // Draw the item text for views other than the Details view.
    if (listView1.View != View.Details)
    {
        e.DrawText();
    }
}
' Draws the backgrounds for entire ListView items.
Private Sub listView1_DrawItem(ByVal sender As Object, _
    ByVal e As DrawListViewItemEventArgs) _
    Handles listView1.DrawItem

    If Not (e.State And ListViewItemStates.Selected) = 0 Then

        ' Draw the background for a selected item.
        e.Graphics.FillRectangle(Brushes.Maroon, e.Bounds)
        e.DrawFocusRectangle()

    Else

        ' Draw the background for an unselected item.
        Dim brush As New LinearGradientBrush(e.Bounds, Color.Orange, _
            Color.Maroon, LinearGradientMode.Horizontal)
        Try
            e.Graphics.FillRectangle(brush, e.Bounds)
        Finally
            brush.Dispose()
        End Try

    End If

    ' Draw the item text for views other than the Details view.
    If Not Me.listView1.View = View.Details Then
        e.DrawText()
    End If

End Sub

Remarques

Cet événement vous permet de personnaliser l’apparence d’un ListView contrôle à l’aide de dessin owner-drawn.This event lets you customize the appearance of a ListView control using owner drawing. Il est déclenché uniquement lorsque le OwnerDraw propriété est définie sur true.It is raised only when the OwnerDraw property is set to true. Pour plus d’informations sur le dessin owner-drawn, consultez la OwnerDraw rubrique de référence de propriété.For more information about owner drawing, see the OwnerDraw property reference topic.

Le DrawItem événement peut se produire pour chaque ListView élément.The DrawItem event can occur for each ListView item. Lorsque le View propriété est définie sur View.Details, le DrawSubItem et DrawColumnHeader événements se produisent également.When the View property is set to View.Details, the DrawSubItem and DrawColumnHeader events also occur. Dans ce cas, vous pouvez gérer le DrawItem événement pour dessiner des éléments communs à tous les éléments, tels que l’arrière-plan et gérer le DrawSubItem événement pour dessiner des éléments pour les sous-éléments, telles que les valeurs de texte.In this case, you can handle the DrawItem event to draw elements common to all items, such as the background, and handle the DrawSubItem event to draw elements for individual subitems, such as text values. Vous pouvez également dessiner tous les éléments le ListView contrôler à l’aide d’un seul des deux événements, même si cela est moins pratique.You can also draw all items in the ListView control using only one of the two events, although this may be less convenient. Pour dessiner des en-têtes de colonnes dans la vue Détails, vous devez gérer le DrawColumnHeader événement.To draw column headers in the details view, you must handle the DrawColumnHeader event.

Notes

En raison d’un bogue dans le contrôle Win32 sous-jacent, le DrawItem événement se produit sans accompagnement DrawSubItem événements une fois par ligne dans la vue Détails lorsque le pointeur de la souris se déplace sur la ligne, et tout élément peint dans un DrawSubItem Gestionnaire d’événements à être peint par un arrière-plan personnalisé dessiné un DrawItem Gestionnaire d’événements.Because of a bug in the underlying Win32 control, the DrawItem event occurs without accompanying DrawSubItem events once per row in the details view when the mouse pointer moves over the row, causing anything painted in a DrawSubItem event handler to be painted over by a custom background drawn in a DrawItem event handler. Consultez l’exemple dans le OwnerDraw rubrique de référence pour une solution de contournement qui invalide chaque ligne lorsque l’événement supplémentaire se produit.See the example in the OwnerDraw reference topic for a workaround that invalidates each row when the extra event occurs. Une autre solution consiste à placer tout votre code de dessin personnalisé un DrawSubItem Gestionnaire d’événements et peindre l’arrière-plan de l’élément entier (y compris des sous-éléments) uniquement lorsque le DrawListViewSubItemEventArgs.ColumnIndex valeur est 0.An alternative workaround is to put all your custom drawing code in a DrawSubItem event handler and paint the background for the entire item (including subitems) only when the DrawListViewSubItemEventArgs.ColumnIndex value is 0.

Pour plus d'informations sur la gestion des événements, voir gestion et déclenchement d’événements.For more information about handling events, see Handling and Raising Events.

S’applique à

Voir aussi