我目前的任务是为WPF应用程序构建类似电子表格的GUI,但我遇到了一些问题。本质上,我想基于列绑定到数据网格,以便一列包含特定年份的数据。因此,鉴于2006年是开始年份,2009年是结束年份,我希望有4列,每列显示给定年份的列数。
这就是我现在在代码隐藏中所拥有的:
private Years m_YearsList;
public Years YearsList
{
get { return m_YearsList; }
set { m_YearsList = value; }
}
public MainWindow()
{
InitializeComponent();
YearsList = LoadData();
TestGrid.DataContext = YearsList;
}
public Years LoadData()
{
var personer = new Years{
new Year
{
Taxed = new Taxed {TaxedField = 10},
NumBuildings = new BuildingsCollection {NumBuildings = 25},
Area = new Area{AreaField = "NoWhere"},
DisplayName = "Person1"
},
new Year
{
Taxed = new Taxed{TaxedField = 2},
NumBuildings = new BuildingsCollection{NumBuildings = 8},
Area = new Area{AreaField = "SomeWhere"},
DisplayName = "Person2"
},
new Year
{
Taxed = new Taxed{TaxedField = 18},
NumBuildings = new BuildingsCollection{NumBuildings = 20},
Area = new Area{AreaField = "UpThere"},
DisplayName = "Person3"
}
};
return personer;
}
}
Year对象只包含两个int和一个字符串。 The Years对象是我的绝望镜头:
public class Years : List<Year>{}
我的XAML:
<DataGrid x:Name="TestGrid" ItemsSource="{Binding}" CanUserAddRows="False" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTextColumn Binding="{Binding Path=NumBuildings}" />
<DataGridTextColumn Binding="{Binding Path=Taxed}" />
<DataGridTextColumn Binding="{Binding Path=Area}" />
</DataGrid.Columns>
</DataGrid>
此代码生成:
如您所见,Year对象每列绑定一个属性,而我基本上希望将它们绑定到一个对象,并且所有属性都在一列中。不幸的是我的WPF技能缺乏。 :(
答案 0 :(得分:1)
我发现this article讨论了创建数据表并对其进行转置(即交换列的行),然后将该对象绑定到数据网格。因此,编写一个方法,从集合中创建转置的数据表,并将此表绑定到数据网格。
问题是这不会真正更新,所以如果你的数据应该由用户在数据网格中编辑,那么你就有问题了。
您可以直接更改数据源,也可以编辑数据网格的ControlTemplate。