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并以某种方式让每个项目跨越多个列,但到目前为止,我也无法解决这个问题.
如果有人有任何提示,我会欢迎他们!
好吧,这在任何情况下都不是“最好的方法”,但我只是把它扔进去。一种像您需要的那样工作的方法是将 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。
不管怎样,希望这能有所帮助。
| 归档时间: |
|
| 查看次数: |
3538 次 |
| 最近记录: |