Ler em inglês

Compartilhar via


VirtualizationMode Enumeração

Definição

Especifica o método que VirtualizingStackPanel usa para gerenciar a virtualização de seus itens filho.

C#
public enum VirtualizationMode
Herança
VirtualizationMode

Campos

Recycling 1

Reutiliza os contêineres de item.

Standard 0

Criar e descarta os contêineres de item.

Exemplos

O exemplo a seguir cria um ListBox e define a VirtualizationMode propriedade anexada como Reciclagem.

XAML
<StackPanel>

  <StackPanel.Resources>
    <src:LotsOfItems x:Key="data"/>
  </StackPanel.Resources>

  <ListBox Height="150" ItemsSource="{StaticResource data}" 
             VirtualizingStackPanel.VirtualizationMode="Recycling" />

</StackPanel>

O exemplo a seguir mostra os dados usados no exemplo anterior.

C#
public class LotsOfItems : ObservableCollection<String>
{
    public LotsOfItems()
    {
        for (int i = 0; i < 1000; ++i)
        {
            Add("item " + i.ToString());
        }
    }
}

Comentários

Por padrão, um VirtualizingStackPanel item cria um contêiner de item para cada item visível e o descarta quando ele não é mais necessário (como quando o item é rolado para fora do modo de exibição). Quando um ItemsControl contém muitos itens, o processo de criação e descarte de contêineres de itens pode afetar negativamente o desempenho. Quando VirtualizationMode é definido como Reciclagem, o VirtualizingStackPanel item reutiliza contêineres de item em vez de criar um novo cada vez.

Quando VirtualizingStackPanel não é possível reciclar contêineres de itens, ele usa o modo padrão de virtualização, que é criar e descartar contêineres de itens para cada item. A lista a seguir descreve casos em que não VirtualizingStackPanel é possível reciclar contêineres de item:

  • O ItemsControl item contém contêineres de itens de tipos diferentes. Por exemplo, um Menu pode ter itens que usam objetos e Separator objetos MenuItem como os contêineres de item.

  • Você cria explicitamente os contêineres de item para o ItemsControl.

Aplica-se a

Produto Versões
.NET Framework 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
Windows Desktop 3.0, 3.1, 5, 6, 7

Confira também