如何在WPF DataGrid中显示数组元素?

时间:2011-04-07 13:52:57

标签: .net wpf datagrid valueconverter

我正在尝试在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的文章,但我不确定这是我需要的。

1 个答案:

答案 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;

看起来像什么(当然缺少标题和一切)

A screenshot of a grid with checkboxes...


编辑为了使上面的代码更清晰,你应该在items-class中公开一个静态属性,它在创建数组时统一使用,在创建列时可能会使用data[0].Values.Length如果数据集合为空,则抛出异常。