我正在尝试在WPF DataGrid中显示一系列行,其中每行包含一个布尔数组(其数量对于所有行都相同,它不是锯齿状的2D数组)我想要显示为各列,例如
Name | Day 1 | Day 2 | Day 3 | Day 4 | Day 5 | Day 6 |
-----------------------------------------------------------------
Bring out Trash | X | | X | | | X |
Pay Bills | | | | | X | |
Commit Suicide | | | | | | X |
目前,我正在将此类用于我的DataGrid行:
private class GridRow {
public string Name { get; set; }
public char Day1 { get; set; }
public char Day2 { get; set; }
public char Day3 { get; set; }
public char Day4 { get; set; }
public char Day5 { get; set; }
public char Day6 { get; set; }
public char Day7 { get; set; }
public char Day8 { get; set; }
public char Day9 { get; set; }
}
在现实世界的情况下,制作128个布尔值。它暂时完成了工作(只要没有人创建长度超过128天的循环计划),但这是一个相当丑陋的解决方案。
我可以以某种方式将一组布尔值输入DataGrid吗?我看了很多关于实现ValueConverters的文章,但我不确定这是我需要的。
答案 0 :(得分:11)
我认为你必须为此处理代码......
示例:
测试类:
public class TestRow
{
private bool[] _values = new bool[10];
public bool[] Values
{
get { return _values; }
set { _values = value; }
}
public TestRow(int seed)
{
Random random = new Random(seed);
for (int i = 0; i < Values.Length; i++)
{
Values[i] = random.Next(0, 2) == 0 ? false : true;
}
}
}
如何生成测试数据&amp;列:
DataGrid grid = new DataGrid();
var data = new TestRow[] { new TestRow(1), new TestRow(2), new TestRow(3) };
grid.AutoGenerateColumns = false;
for (int i = 0; i < data[0].Values.Length; i++)
{
var col = new DataGridCheckBoxColumn();
//Here i bind to the various indices.
var binding = new Binding("Values[" + i + "]");
col.Binding = binding;
grid.Columns.Add(col);
}
grid.ItemsSource = data;
看起来像什么(当然缺少标题和一切)
编辑为了使上面的代码更清晰,你应该在items-class中公开一个静态属性,它在创建数组时统一使用,在创建列时可能会使用data[0].Values.Length
如果数据集合为空,则抛出异常。