2015-04-07 43 views
1

我是c#的新手。我需要在datagridview的“selected”列中有一个复选框字段,而不是当前显示的“False”(或“True”)文本。这个datagridview是数据绑定的,数据是通过读取一个xml文件获得的。我怎样才能做到这一点?如何将复选框添加到绑定到数据源的datagridview?

在写入xml文件之前,这就是我所做的。

DataTable dtGens = new DataTable(); //creates a new Datatable object for the Gens 

dtGens.TableName = "Gen Types"; 

DataColumn dc1 = new DataColumn("Generator"); 
DataColumn dc2 = new DataColumn("alpha"); 
DataColumn dc3 = new DataColumn("beta"); 
DataColumn dc4 = new DataColumn("circuit breaker"); 
DataColumn dc5 = new DataColumn("description"); 
DataColumn dc6 = new DataColumn("Selected",System.Type.GetType("System.Boolean")); 

dtGens.Columns.Add(dc1); //associates the columns to the dtGens datatable 
dtGens.Columns.Add(dc2); 
dtGens.Columns.Add(dc3); 
dtGens.Columns.Add(dc4); 
dtGens.Columns.Add(dc5); 
dtGens.Columns.Add(dc6); 

DataRow drow; 
for (int i = 0; i < 50; i++) 
{ 
    drow = dtGens.NewRow(); 
    drow["Generator"] = "Gen " + (i + 1).ToString(); 
    drow["alpha"] = 0.0; 
    drow["beta"] = 0.0; 
    drow["circuit breaker"] = 0.0; 
    drow["description"] = "myGen"; 
    drow["Selected"] = false; 
    dtGens.Rows.Add(drow); 

} 

//creates a new DataSet Object that will help write generator data to XML 
DataSet feederProject = new DataSet(); 
feederProject.Tables.Add(dtGens); 
feederProject.WriteXml("Generators.xml"); 
//preview 
DataSet feederProject = new DataSet(); 
feederProject.ReadXml("Generators.xml"); 
dataGridViewLoadsDGs.DataSource = feederProject.Tables[0]; 

回答

2

自动绑定到布尔类型A列显示的复选框。问题是DataTable的模式信息在写入XML时会丢失。 为了防止出现这种情况,您可以使用an overload of DataSet.WriteXml,将XmlWriteMode作为参数,它允许您选择写入架构信息。

feederProject.WriteXml("Generators.xml", XmlWriteMode.WriteSchema); 
2

为了能够代表一个绑定的布尔数据,因为你需要在DataGridView的AutoGenerateColumns属性设置为false复选框列。然后手动添加的列和用于必须是复选框列的列设置DataGridViewCheckBoxColumn的实例:

dataGridViewLoadsDGs.AutoGenerateColumns = false; 
... 
dataGridViewLoadsDGs.Columns.Add(new DataGridViewCheckBoxColumn()); 
+0

谢谢。不过,我仍然需要将原始数据关联到新的复选框列。只需添加复选框Column不会帮助我。即如果原始数据被设置为“真”,则应该勾选复选框,反之亦然。我已经检查过,writexml(string)方法实际上将所有列转换为字符串,而不管用于数据表列的原始数据类型是什么。 –

相关问题