C#/ WPF:Toolkit DataGrid - 转置行和列

时间:2009-09-24 08:45:59

标签: c# wpf datagrid columnheader

我有一个

List<DetailObject> someList;

看起来像这样:

    public class DetailObject
    {
        public string Titel { get; set; }
        public int Value1 { get; set; }
        public int Value2 { get; set; }
        public int Value3 { get; set; }
    }

有谁知道我如何使用(使用DataGrid.AutoGenerateColumns =“True”)'string Titel'作为RowHeader和其他成员作为“Row”内容的值?没有任何修改,它会向我显示“Titel”作为ColumnHeader并将Titel的值显示为row,dito for “Value1”作为ColumnHeader,Value1的值作为行等。

感谢您的帮助!

干杯

编辑: 为了更好地理解,这就是我所拥有的

[Titel]       [Value1]       [Value2]       [Value3]
[Item1.Titel] [Item1.Value1] [Item1.Value2] [Item1.Value3] 
[Item2.Titel] [Item2.Value1] [Item2.Value2] [Item2.Value3] 
[Item3.Titel] [Item3.Value1] [Item3.Value2] [Item3.Value3] 

这就是我要找的东西:

[Item1.Titel]  [Item2.Titel]  [Item3.Titel] 
[Item1.Value1] [Item2.Value1] [Item3.Value1]
[Item1.Value2] [Item2.Value2] [Item3.Value2]
[Item1.Value3] [Item2.Value3] [Item3.Value3]

EDIT2: 我在这里找到了一个不错的方法: http://codemaverick.blogspot.com/2008/02/transpose-datagrid-or-gridview-by.html

4 个答案:

答案 0 :(得分:5)

这个帖子有点旧但也许有人仍然感兴趣...我也在寻找转换WPF DataGrid的方法,最后我在CodePlex上找到了以下开源项目:

Transposed WPF DataGrid

希望这有帮助。

答案 1 :(得分:3)

您可以像这样使用RowHeaderTemplate

<toolkit:DataGrid>
  <toolkit:DataGrid.RowHeaderTemplate>
    <DataTemplate>
      <TextBlock Text="{Binding Item.Titel, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type toolkit:DataGridRow}}}"/>
    </DataTemplate>
  </toolkit:DataGrid.RowHeaderTemplate>
</toolkit:DataGrid>

您还必须将AutoGenerateColumns设置为false并创建自己的列,以避免Titel属性也显示为列。

修改

我现在明白你要转置DataGrid。我认为简单但有些“hacky”的解决方案是创建一个“转置”对象列表。要做到这一点,你必须事先知道原始列表中有多少个对象,然后创建一个具有与对象一样多的属性的新类。

class TransposedDetailObject {
  public String Column1 { get; set; }
  public String Column2 { get; set; }
  public String Column3 { get; set; }
}

var transposedList new List<TransposedDetailObject> {
  new TransposedDetailObject {
    Column1 = someList[0].Titel,
    Column2 = someList[2].Titel,
    Column3 = someList[3].Titel
  },
  new TransposedDetailObject {
    Column1 = someList[0].Value1,
    Column2 = someList[2].Value1,
    Column3 = someList[3].Value1
  },
  ...
};

较少“hacky”的解决方案是修改DataGrid的控件模板以交换行和列。但是,DataGrid是一个复杂的控件,修改控件模板可能有点压倒性。

答案 2 :(得分:3)

将业务对象列表转换为您已从对象属性创建列的数据表,并将其设置为datagrid的itemsource。如果要启用编辑,则必须迭代数据表并手动将值应用回业务对象。反射可能有助于使网格通用。只是一些想法。

答案 3 :(得分:1)

我认为更简洁的方法是在您的方案中使用ItemsControl代替DataGrid

按照this blog post上的说明操作并创建您自己的ItemTemplate以获得最大程度的控制权。这样,您就可以为每个列创建一个模板(可以是Datagrid本身)。