Leer en inglés

Compartir a través de


ListView.DrawSubItem Evento

Definición

Se produce cuando se dibuja la vista de detalles de un control ListView y el valor de la propiedad OwnerDraw se ha establecido en true.

C#
public event System.Windows.Forms.DrawListViewSubItemEventHandler DrawSubItem;
C#
public event System.Windows.Forms.DrawListViewSubItemEventHandler? DrawSubItem;

Tipo de evento

Ejemplos

En el ejemplo de código siguiente se proporciona una implementación de un DrawSubItem controlador de eventos. Para obtener el ejemplo completo, consulte el tema de OwnerDraw referencia.

C#
// Draws subitem text and applies content-based formatting.
private void listView1_DrawSubItem(object sender,
    DrawListViewSubItemEventArgs e)
{
    TextFormatFlags flags = TextFormatFlags.Left;

    using (StringFormat sf = new StringFormat())
    {
        // Store the column text alignment, letting it default
        // to Left if it has not been set to Center or Right.
        switch (e.Header.TextAlign)
        {
            case HorizontalAlignment.Center:
                sf.Alignment = StringAlignment.Center;
                flags = TextFormatFlags.HorizontalCenter;
                break;
            case HorizontalAlignment.Right:
                sf.Alignment = StringAlignment.Far;
                flags = TextFormatFlags.Right;
                break;
        }

        // Draw the text and background for a subitem with a 
        // negative value. 
        double subItemValue;
        if (e.ColumnIndex > 0 && Double.TryParse(
            e.SubItem.Text, NumberStyles.Currency,
            NumberFormatInfo.CurrentInfo, out subItemValue) &&
            subItemValue < 0)
        {
            // Unless the item is selected, draw the standard 
            // background to make it stand out from the gradient.
            if ((e.ItemState & ListViewItemStates.Selected) == 0)
            {
                e.DrawBackground();
            }

            // Draw the subitem text in red to highlight it. 
            e.Graphics.DrawString(e.SubItem.Text,
                listView1.Font, Brushes.Red, e.Bounds, sf);

            return;
        }

        // Draw normal text for a subitem with a nonnegative 
        // or nonnumerical value.
        e.DrawText(flags);
    }
}

Comentarios

Este evento le permite personalizar la apariencia de un ListView control mediante el dibujo del propietario. Se genera solo cuando la OwnerDraw propiedad se establece true en y la View propiedad se establece en View.Details. Para obtener más información sobre el dibujo del propietario, consulte el OwnerDraw tema de referencia de propiedades.

Nota

La información del subelemento suele aparecer en la vista de mosaico, así como en la vista de detalles, pero en la vista de mosaico, debe dibujarse en un controlador para el DrawItem evento.

El DrawSubItem evento puede producirse para cada ListView subelemento. Puede controlar el DrawItem evento para dibujar elementos comunes a todos los subelementos, como el fondo, y controlar el DrawSubItem evento para dibujar elementos para subelementos individuales, como valores de texto. También puede dibujar todos los elementos del ListView control utilizando solo uno de los dos eventos, aunque esto puede ser menos conveniente. Para dibujar encabezados de columna en la vista de detalles, debe controlar el DrawColumnHeader evento.

Nota

El DrawSubItem evento no se produce para ningún subelemento para el que no se haya agregado ningún ColumnHeader objeto a la Columns colección. Tenga en cuenta también que el primer subelemento de cada ListViewItem objeto representa el propio elemento primario y se muestra en la primera columna.

Para obtener más información sobre el manejo de eventos, consulte controlar y provocar eventos.

Se aplica a

Producto Versiones
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Consulte también