我有一个看似简单的问题,我动态创建了一个 DataTable,并且成功地向其中添加了行。但是,我有一列将拥有一个标志,这是一个图像。我已经将两个标志(.png 图像)导入到项目资源中。然而,我无法将该列的 DataType 设置为 System.Type.Bitmap,因为 DataColumn 不支持该设置,可以在此处查看。我看到一个解决方案,建议我将 DataType 设置如下:
然而,这会抛出一个异常,指明编译器期望的是 Byte[],但得到了 Bitmap。
以下是我如何向 DataTable 添加行。
这是我的问题,我应该将图像列保存为哪种数据类型,以便在显示到DataGridView时能够看到图像。如果没有在DataGridView上设置数据类型,而不是显示图像,我会得到文本
dataColumn = new DataColumn("Flag");
dataColumn.DataType = System.Type.GetType("System.Byte[]"); //Replacing System.Byte[] with System.Type.Bitmap throws Type Exception
dataTable.Columns.Add(dataColumn);
然而,这会抛出一个异常,指明编译器期望的是 Byte[],但得到了 Bitmap。
以下是我如何向 DataTable 添加行。
row["Part Number"] = part;
row["Module Name"] = populator.LookUpAValue(moduleSql);
row["Flag"] = Properties.Resources.Yellow_Flag;
row["Location"] = populator.LookUpAValue(nameSql);
dataTable.Rows.Add(row);
这是我的问题,我应该将图像列保存为哪种数据类型,以便在显示到DataGridView时能够看到图像。如果没有在DataGridView上设置数据类型,而不是显示图像,我会得到文本
System.Drawing.Bitmap
。