我有两个comboBoxes
。首先我选择Brand,在第二个我选择模型。我还想根据模型选择显示picture
。在我添加FileInfo
列之前,一切似乎都有效。现在代码无效(我甚至无法选择品牌和型号 - comboboxes are empty
)。出了什么问题:
dtCategories = new DataTable();
dtCategories.Columns.Add("CategoryID", typeof(int));
dtCategories.Columns.Add("CategoryName", typeof(string));
dtCategories.Rows.Add(0, "--Select--");
dtCategories.Rows.Add(1, "Audi");
dtCategories.Rows.Add(2, "BMW");
dtCategories.Rows.Add(3, "Mercedes");
dtItems = new DataTable();
dtItems.Columns.Add("ItemID", typeof(int));
dtItems.Columns.Add("ItemName", typeof(string));
dtItems.Columns.Add("CategoryID", typeof(int));
dtItems.Columns.Add("Obrazek", typeof(FileInfo));
dtItems.Rows.Add(2, "A1", 1, "a1.jpeg");
dtItems.Rows.Add(3, "A3", 1, "a3.jpeg");
dtItems.Rows.Add(4, "A4", 1, "a5.jpeg");
dtItems.Rows.Add(5, "Seria 1", 2, "bmw1.jpeg");
dtItems.Rows.Add(6, "Seria 2", 2, "bmw3.jpeg");
dtItems.Rows.Add(7, "Seria 3", 2, "bmw5.jpeg");
dtItems.Rows.Add(8, "C Klasa", 3, "C Klasa.jpeg");
dtItems.Rows.Add(9, "E Klasa", 3, "E Klasa.jpeg");
dtItems.Rows.Add(10, "S Klasa", 3, "S Klasa.jpeg");
cbCategory.DisplayMember = "CategoryName";
cbCategory.ValueMember = "CategoryID";
cbCategory.DataSource = dtCategories;
并且:
private void cbCategory_SelectedIndexChanged(object sender, EventArgs e)
{
int categoryId = Convert.ToInt32(cbCategory.SelectedValue);
if (categoryId > 0)
{
DataTable dtTemp = dtItems.Select(string.Format("CategoryID = {0}", categoryId)).CopyToDataTable();
DataRow drTemp = dtTemp.NewRow();
drTemp["ItemID"] = 0;
drTemp["ItemName"] = "--Select--";
drTemp["CategoryID"] = 0;
dtTemp.Rows.InsertAt(drTemp, 0);
cbItems.DisplayMember = "ItemName";
cbItems.ValueMember = "ItemID";
cbItems.DataSource = dtTemp;
pictureBox1.Image = Image.FromFile(dtTemp.Columns[3].ToString());
}
else if (cbItems.DataSource != null)
{
cbItems.SelectedIndex = 0;
}
}
答案 0 :(得分:1)
FileInfo
不是DataTable
列的有效数据类型。有关详细信息,请参阅DataColumn.DataType Property。
你收到某种例外吗?
可能是您的图片路径不正确。 您可以尝试使用此代码,这可能更容易调试:
var imagePath = dtTemp.Columns[3].ToString();
if (File.Exists(imagePath))
{
var image = Image.FromFile(imagePath);
pictureBox1.Image = image;
}
else
{
throw new FileNotFoundException();
// of course something more subtle is advisable
}
答案 1 :(得分:0)
问题不在于第4列的数据类型是FileInfo
。它是在添加行时不提供一个,而是为第4列提供string
类型。做
dtItems.Rows.Add(2, "A1", 1, new FileInfo("a1.jpeg"));
dtItems.Rows.Add(3, "A3", 1, new FileInfo("a3.jpeg"));
//etc..
也就是说,FileInfo通常不适合DataTable。对于ur自定义表,它可能有效,但从db直接加载到该数据表时将不兼容。但是你的数据表可以正常DataSource
。
cbItems.DataSource = dtItems; //fine in your case.