背景

我有一个继承自 TreeView 的自定义控件,并被修改为以数据网格样式显示。我看到的问题是扩展树时的性能。这在我对树视图的研究中很常见。使用 WPF 性能工具进行检查后,我注意到 ItemsPresenter 类使用常规堆栈面板而不是虚拟化堆栈面板。

enter image description here

这是使用 ScrollContentPresenter 的代码部分(如图所示)。

<ScrollContentPresenter Name="PART_ScrollContentPresenter"
      KeyboardNavigation.DirectionalNavigation="Local"
      Content="{TemplateBinding Content}"
      ContentTemplate="{TemplateBinding ContentTemplate}"
      CanContentScroll="{TemplateBinding CanContentScroll}"
      SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>

这是传入的模板。

    <ControlTemplate TargetType="CommonControls:TreeListViewItem508">
    <Grid >
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="*"/>
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="Auto"/>
        </Grid.RowDefinitions>
        <Border x:Name="item">
            <Border Name="InnerBorder">
                <Grid Style="{StaticResource GridBackgroundStyle}">
                    <Rectangle Visibility="Collapsed" Fill="#75FFFFFF" Name="UpperHighlight" />
                </Grid>
            </Border>
        </Border>
        <ItemsPresenter Grid.Row="1" Name="ItemsHost" />
    </Grid>
</ControlTemplate>

问题

是否可以强制项目演示者使用虚拟化堆栈面板?

笔记

  • 我已经尝试将 ItemsPresenter 包装在 ScrollViewer 中,但这给出了不需要的结果(每行都有滚动条)。
  • 我对选项 CanContentScroll = true 进行了硬编码作为测试,因为当其设置为 false 时,这会禁用虚拟化。
  • 该控件已投入生产并在多个地方使用,因此我目前无法选择替换/重写/或对设计进行重大修改。我只是想尽可能地覆盖这一节。

非常感谢任何建议或选择。

解决:

我通过将其添加到样式中来修改模板的样式,并将堆栈面板切换为虚拟化。

 <Setter Property="ItemsPanel">
        <Setter.Value>
            <ItemsPanelTemplate>
                <VirtualizingStackPanel />
            </ItemsPanelTemplate>
        </Setter.Value>
    </Setter>
有帮助吗?

解决方案

尝试

      <TreeView>
        <TreeView.ItemsPanel>
            <ItemsPanelTemplate>
                <VirtualizingStackPanel/>
            </ItemsPanelTemplate>
        </TreeView.ItemsPanel>
    </TreeView>
.

<TreeView VirtualizingStackPanel.IsVirtualizing="True">
.

expiosseLy替换树视图,使用treeview控件名称。

希望有助于

paul

其他提示

您可以使用 VirtualizingStackPanel, ,但请注意 虚拟化 StackPanel 不仅仅是使用 VirtualizingStackPanel

这是一个使用上面发布的链接中找到的代码的示例,其中列出了所需的项目:

<ItemsControl ...
    VirtualizingStackPanel.IsVirtualizing="True" <!-- this is needed -->
    ScrollViewer.CanContentScroll="True" > <!-- this is needed -->
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <VirtualizingStackPanel />  <!-- this is needed -->
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
    <ItemsControl.Template>
        <ControlTemplate>
            <Border ...>
                <ScrollViewer> <!-- this is needed -->
                    <ItemsPresenter />
                </ScrollViewer>
            </Border>
        </ControlTemplate>
    </ItemsControl.Template>
</ItemsControl>
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top