在WPF网格/列表中跨越多列的最佳方法?

Chr*_*mes 6 wpf grid datagrid listbox columnspan

我有一个我在WPF中编写的自定义用户控件来显示一些数据.我想在列表中显示此usercontrol,但我还想提供多个列标题(匹配用户cotrol上的一些属性),以便用户可以对usercontrol中包含的属性进行排序.

我不确定最好的办法.

我目前有一个ListBox显示这些用户控件,但ListBox没有标题,我无法弄清楚如何在ListBox上放置多个标题.

理想情况下,我喜欢这样的事情:

Header1   Header2  Header3   Header4
[UserControlThatSpansAllFourColumns]
Run Code Online (Sandbox Code Playgroud)

我的另一个想法是使用DataGrid并以某种方式让每个项目跨越多个列,但到目前为止,我也无法解决这个问题.

如果有人有任何提示,我会欢迎他们!

ASa*_*nch 3

好吧,这在任何情况下都不是“最好的方法”,但我只是把它扔进去。一种像您需要的那样工作的方法是将 ListView 与自定义 ItemContainerStyle 一起使用,该自定义 ItemContainerStyle 使用 a 而不是<ContentPresenter>默认的<GridViewRowPresenter>。这个简短的 XAML 在某种程度上证明了这一点:

<ListView>
    <ListView.ItemContainerStyle>
        <Style TargetType="ListViewItem">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="ListViewItem">
                        <ContentPresenter/>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </ListView.ItemContainerStyle>
    <ListView.View>
        <GridView>
            <GridViewColumn Header="Header1"/>
            <GridViewColumn Header="Header2"/>
        </GridView>
    </ListView.View>

    <Button>Item1</Button>
    <Button>Item2</Button>

</ListView>
Run Code Online (Sandbox Code Playgroud)

在这里,您可以获得列标题,并且项目跨越整个列表视图。然而,在这个解决方案中,项目的渲染有点像在它自己的世界中。它并没有真正连接到为 ListView 定义的列。因此,我想使这项工作更好的一种方法是提供您自己的<RowPresenter>实现,该实现实际上考虑了父列表视图中定义的 GridViewColumns。

不管怎样,希望这能有所帮助。