[英]C# winform create columns in datagridview with observableCollection
我以前是用一个简单的dataTable加载数据的,是这样的:
DataTable dt = new DataTable("grid");
//split array to width X height dataTable
// create columns
for (int i = 0; i < width; i++)
{
dt.Columns.Add();
}
for (int i = 0; i < height; i++)
{
// create a DataRow using .NewRow()
DataRow row = dt.NewRow();
// iterate over all columns to fill the row
for (int j = 0; j < width; j++)
{
row[j] = grid.Cells[j + (width * i)].State.ToString();
}
// add the current row to the DataTable
dt.Rows.Add(row);
}
dataGridView1.DataSource = dt;
那行得通,但还不够好,因为我想快速更新100x100的颜色矩阵,所以我想到了一个可观察的集合。
我现在有以下代码:
ObservableCollection<String> data = new ObservableCollection<String>();
dataGridView1.DataSource = new BindingSource { DataSource = data };
for (int i = 0; i < grid.Cells.Length; i++)
{
data[i] = grid.Cells[i].State.ToString();
}
(网格是我的模型)
这似乎加载了所有数据,但是我没有对列的表示,所以我只有行。
如何指定列数?
我的方向正确吗?
我使用了我的第一行代码,刚刚添加了:
dataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.None;
现在它可以正常工作了。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.