質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

Q&A

解決済

1回答

1002閲覧

DataGridView 画面を開いた時にイメージを表示させたい。

退会済みユーザー

退会済みユーザー

総合スコア0

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

0グッド

0クリップ

投稿2020/03/30 10:23

編集2020/03/30 23:20

前提・実現したいこと

お世話になっております。
今回も宜しくお願い致します。
前スレッドhttps://teratail.com/questions/247461の続きのようなものです。
※BindingSource bindingSourceを追加しています。↑

前のスレッドを見ていただけると分かると思うのですが、MySqlでデータを取得しています。
その中で、ファイルパスを取得しているのですが画面表示した時点でイメージが表示されるようにしたいです。
下記イメージの流れです。

①画面表示時(一部くりぬいたもの)
イメージ説明
②編集・追加する際は別画面から選択します。
※別画面の方もイメージが表示されていない状態です。
イメージ説明
③選択したら元の画面に反映される感じです。
反映したらDBに書き込みます。
イメージ説明

発生している問題・試したこと

修正:https://shumitestitblog.blogspot.com/2013/02/vbnetdatagridview.html?showComment=1583713085068#c472012352245846462
上記のURLを参照にコードを書いてみました。

vb

1'データ取得時アイコン画像を表示する 2Private Sub DataGridView1_CellFormatting(ByVal sender As Object, ByVal e As System.Windows.Forms.DataGridViewCellFormattingEventArgs) Handles DataGridView1.CellFormatting 3 Dim image1 As New Bitmap(Form1.Txt_path.Text)→別画面からパスを取得 4 Dim dgv As DataGridView = CType(sender, DataGridView) 5 '"Image"列のセルか確認する 6 If dgv.Columns(e.ColumnIndex).Name = "Clm_icon" AndAlso e.RowIndex >= 0 AndAlso TypeOf (dgv("Clm_icon", e.RowIndex).Value) Is Integer Then 7 '"Column1"列のセルの値によって表示する画像を決定する 8 Select Case CInt(dgv("Clm_icon", e.RowIndex).Value) 9 Case 1 10 e.Value = image1 11 e.FormattingApplied = True 12 End Select 13 End If 14 End Sub

これを実行すると「使用されたパラメーターが有効ではありません。」
とエラーメッセージが表示されるのですが、そもそもあっていないのかも…?とも思います。
上記コードであっているのであれば修正点を教えて欲しいです。
全然的外れであれば、参考URLでもいいので教えて欲しいです。
何卒、宜しくお願い致します。

補足情報(FW/ツールのバージョンなど)

不明な点はご指摘下さい。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

まず、CellFormattingイベントでImageの読み込みを行うべきではありません。
このイベントは描画が行われるタイミングで発生するため、無駄に画像を読み込むことになります。
ですので、DataGirdViewに表示すべきデータを取得したタイミングで画像を読み込みDataGridViewに設定すべきかと思います。

VBNET

1Datagridview1.DataSource = dt 2 3For Each r As DataGridViewRow in DataGridView1.Rows 4 5 r.Cells(アイコンを表示するColumnのインデックス).Value = Image.FromFile(r.Cells(ファイル名が格納されているColumnのインデックス).Value) 6 7Next 8

みたいな感じですかね

また、別フォームで選択した場合にも戻ってきたときに画像を読み込み、セルに設定するという形がいいのではないかと思います。

投稿2020/03/30 13:45

編集2020/03/31 00:07
YAmaGNZ

総合スコア10258

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/03/30 23:34

ご回答ありがとうございます。 FromLoadでデータを取得しているため、そこに加えてみました。 For Each r As DataGridViewRow In DataGridView1.Rows r.Cells(1).Image = Image.FromFile(r.Cells(2)) Next としてみたのですが、①「r.Cells(1).Image」と②「r.Cells(2)」の部分でエラーメッセージが表示されました。②の方は後ろにToStringを加えたところエラーは消えました。 ①の部分なんですが、ImageはSystem.Windows.Forms.DataGridViewCellのメンバーではありません。と出てしまいました。
YAmaGNZ

2020/03/31 00:06

すみません。記載したソースに誤りがありました。 修正しておきます。
退会済みユーザー

退会済みユーザー

2020/03/31 01:13

無事修正していただいたソースで表示することができたのですが、Nullを回避する場合はどのようにif文を書いたらよろしいのでしょうか?
YAmaGNZ

2020/03/31 01:21

パスの入っている部分が何も入っていない状態か判断したいということでしょうか? そうなのであれば、「VB.NET DBNull 判断」といった感じで検索していただければよろしいかと思います。
退会済みユーザー

退会済みユーザー

2020/03/31 02:19

できました。 ご丁寧に教えていただきありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問