微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

wpf – 当存在基于触发器隐藏显示元素的复杂数据模板时,我的ListView或ListBox控件大小不会缩小?

我有一个ListView元素,每个ListViewItem都有一个DataTemplate定义如下.运行时,ListView的高度不会折叠到视图中的项目上,这是不合需要的行为:

<DataTemplate x:Key="LicenseItemTemplate">
    <Grid>
        <Grid.RowDeFinitions>
            <RowDeFinition Height="Auto"  />
            <RowDeFinition Height="Auto" />
        </Grid.RowDeFinitions>
        <TextBlock Grid.Row="0" Text="{Binding company}"></TextBlock>
        <Grid Grid.Row="1" Style="{StaticResource HiddenWhenNotSelectedStyle}">
            <Grid.RowDeFinitions>
                <RowDeFinition />
            </Grid.RowDeFinitions>
            <Button Grid.Row="0">ClickIt</Button>
        </Grid>
    </Grid>
</DataTemplate>

外部网格的第二行应用了一个样式,如下所示.样式的目的是公开所选数据项的详细视图:

<Style targettype="{x:Type Grid}" x:Key="HiddenWhenNotSelectedStyle" >
    <Style.Triggers>
        <DataTrigger
            Binding="{Binding Path=IsSelected,RelativeSource={
                        RelativeSource 
                        Mode=FindAncestor,AncestorType={x:Type ListViewItem}
                        }
                        }" 
            Value="False">
            <Setter Property="Grid.Visibility" Value="Collapsed" />
        </DataTrigger>
        <DataTrigger
            Binding="{Binding Path=IsSelected,AncestorType={x:Type ListViewItem}
                        }
                        }" 
            Value="True">
            <Setter
                Property="Grid.Visibility"
                Value="Visible"
            />
        </DataTrigger>
    </Style.Triggers>
</Style>

ListView呈现如下:

当没有选择任何元素时,所需的外观是这样的:

…当然,当通过选择使第二个网格可见时,ListView的高度调整以适应附加内容.我该怎么做才能获得理想的行为?

解决方法

在TechEd讨论WPF人员的问题时,我向微软员工展示了这个问题.他不知所措.

我们下载了一个查询WPF布局的工具,并将该容器标识为ListView中的“Virtualizing Stack Panel”元素.

在后续电子邮件中,他写道:“这是VirtualizingStackPanel的错误.我已经开了一个关于它的错误.希望它可以在将来的版本中修复.解决方法(使用StackPanel)现在应该没问题,只要您不需要ListView来虚拟化其内容.

错误涉及VSP测量算法中的一个步骤,该算法记住发现的最大尺寸,并强制所有未来的测量调用报告大小至少一样大.在您的情况下,VSP最初是在触发任何触发器之前测量的,因此它会计算大小,就像所有内容都可见一样.当触发器触发并折叠按钮时,度量算法会计算正确的(小)大小,但会强制结果再次变大.评论说明了在滚动时避免不必要的重新布局,但即使没有滚动,代码仍在运行.“

解决方法涉及使用以下代码新模板化ListView:

<ListView.ItemsPanel>
  <ItemsPanelTemplate>
    <StackPanel/>
  </ItemsPanelTemplate>
</ListView.ItemsPanel>

这导致列表行为按预期工作,但它具有不具备VirtualizingStackPanel的内存管理功能的缺点.对我来说,这是合适的;列表项目一次不会超过2000左右.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐