1

我有两个comboBoxes。首先我选择品牌,第二个我选择型号。我还想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;
        }
    }
4

2 回答 2

1

FileInfo不是 a 的列的有效数据类型DataTable。有关详细信息,请参阅DataColumn.DataType 属性

您是否收到某种例外情况?

可能是您的图像路径不正确。你可以试试这段代码,它可能更容易调试:

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
}
于 2013-01-21T20:18:32.943 回答
0

问题不在于第 4 列的数据类型是FileInfo. 它是您在添加行时没有提供一个,而是string第 4 列的类型。做

dtItems.Rows.Add(2, "A1", 1, new FileInfo("a1.jpeg"));
dtItems.Rows.Add(3, "A3", 1, new FileInfo("a3.jpeg"));
//etc..

也就是说,FileInfo 通常不是 DataTable 的合适类型。对于您的自定义表,它可能有效,但从 db 直接加载到该数据表时将不兼容。但是你的数据表很好DataSource

cbItems.DataSource = dtItems; //fine in your case.
于 2013-01-22T05:24:26.187 回答