繁体   English   中英

C#Winform使用ObservableCollection在datagridview中创建列

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM