1

私は2つ持ってい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の列の有効なデータ型ではありません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 に答える