Хит стиля
У меня есть сценарий для отображения почти 10000 элементов в пользовательском контроле WPF. Я использую ItemsControl, и каждый элемент представлен кнопкой (элементы простой текст с возможностью нажатия). Я определил стиль для кнопки в ресурсах usercontrol.
Все работает нормально, пока в моем списке более 5000 элементов, тогда краска пользовательского интерфейса начинает замедляться - для отображения 10000 элементов требуется около 3+ минут.
Если я перенесу стиль из ресурсов в Button.Style, то также потребуется 2,5 минуты для отображения элементов.
Если я полностью удаляю стиль, я не вижу заметных задержек. Единственная причина использовать стиль Button - это присвоить границе ContentPresenter (названной Chrome в коде ниже) тот же фон, что и кнопке, в противном случае - серый.
Пожалуйста, дайте мне знать, как я могу эффективно использовать стили, не нанося удар по производительности, или как я могу закрасить фон границы ContentPresenter таким же цветом, как у кнопки (прозрачный будет работать как-то).
Вот пример кода:
<UserControl.Resources>
<Style x:Key="ButtonStyle" TargetType="{x:Type Button}" BasedOn="{x:Null}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border x:Name="Chrome" Background="{TemplateBinding Property=Background}">
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" RecognizesAccessKey="True"
SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}">
<ContentPresenter.Resources>
<Style TargetType="{x:Type TextBlock}" BasedOn="{x:Null}">
<Setter Property="FontSize" Value="{Binding FontSize, RelativeSource={RelativeSource AncestorType={x:Type Button}}}"/>
</Style>
</ContentPresenter.Resources>
</ContentPresenter>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</UserControl.Resources>
<Grid Name="Grid1" Margin="5,5,5,5">
<ScrollViewer HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto" Margin="5,0,0,0">
<Border Name="Border1" Margin="2,2,2,2" BorderBrush="Gray" BorderThickness="2">
<ItemsControl Name="ItemsControl1" ItemsSource="{Binding LargeItems}" FocusVisualStyle="{x:Null}">
<ItemsControl.ItemsPanel>
<ItemsPanelTemplate>
<UniformGrid Columns="{Binding Columns}" Rows="{Binding Rows}"/>
</ItemsPanelTemplate>
</ItemsControl.ItemsPanel>
<ItemsControl.ItemTemplate>
<DataTemplate>
<Border Name="Border1" Background="{Binding BorderBkg}"
BorderThickness="1" Padding="{Binding PaddingVal}">
<Button Name="MyButton" Content="{Binding Label}"
Background="{Binding Background}"
Foreground="{Binding Foreground}"
BorderThickness="0"
BorderBrush="Transparent"
Margin="0"
Style="{StaticResource ButtonStyle}"
IsEnabled="{Binding IsButtonEnabled}"
Command="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ItemsControl}}, Path=DataContext.ButtonAction}"
CommandParameter="{Binding}">
</Button>
</Border>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
</Border>
</ScrollViewer>
</Grid>
Спасибо,
RDV
1 ответ
Кажется, что в вашем ItemControl не реализована виртуализация данных. Вы можете реализовать виртуализацию, добавив VirtualizingPanel.IsVirtualizing="True" VirtualizingPanel.VirtualizationMode="Переработка" в вашем ItemsControl и увидеть разницу в производительности.