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

定義

ListView が描画され、OwnerDraw プロパティが 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 

次のコード例の実装を提供する、DrawItemイベント ハンドラー。The following code example provides an implementation of a DrawItem event handler. 完全な例では、次を参照してください。、OwnerDrawリファレンス トピック。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

注釈

このイベントでは、外観をカスタマイズすることができます、ListViewオーナー描画を使用して制御します。This event lets you customize the appearance of a ListView control using owner drawing. 発生した場合にのみ、OwnerDrawプロパティに設定されてtrueします。It is raised only when the OwnerDraw property is set to true. オーナー描画の詳細については、次を参照してください。、OwnerDrawプロパティの参照トピック。For more information about owner drawing, see the OwnerDraw property reference topic.

DrawItemごとにイベントが発生する可能性がListView項目。The DrawItem event can occur for each ListView item. ときに、Viewプロパティに設定されてView.DetailsDrawSubItemDrawColumnHeaderイベントにも発生します。When the View property is set to View.Details, the DrawSubItem and DrawColumnHeader events also occur. この場合、処理することができます、 DrawItem 、バック グラウンドなど、すべてのアイテムに共通する要素を描画および処理するイベント、DrawSubItemテキスト値などの個々 のサブ項目の要素を描画するイベントです。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. すべての項目を描画することも、ListViewはあまり便利なことが考えられますが、2 つのイベントのいずれかのみを使用を制御します。You can also draw all items in the ListView control using only one of the two events, although this may be less convenient. 詳細ビューで列ヘッダーを描画するために処理する必要があります、DrawColumnHeaderイベント。To draw column headers in the details view, you must handle the DrawColumnHeader event.

注意

基になる Win32 コントロールでのバグにより、DrawItemイベントは発生せずに付属するDrawSubItem行上にマウス ポインターが移動したときに、詳細ビュー内の行ごとに 1 回のイベント、何かの原因で描画される、DrawSubItemイベント ハンドラーを指定カスタムの背景に描画によって描画される、DrawItemイベント ハンドラー。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. 例を参照してください、OwnerDrawを余分なイベントの発生時に、各行を無効にする回避策についてのリファレンス トピック。See the example in the OwnerDraw reference topic for a workaround that invalidates each row when the extra event occurs. 別の回避策にすべてのカスタム描画コードを格納する、DrawSubItemイベント ハンドラーとペイント (サブ項目を含む) 全体の項目の背景を場合にのみ、DrawListViewSubItemEventArgs.ColumnIndex値は 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.

イベントの処理の詳細については、「処理とイベントの発生」を参照してください。For more information about handling events, see Handling and Raising Events.

適用対象

こちらもご覧ください