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

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

新規登録して質問してみよう
ただいま回答率
85.35%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

解決済

2回答

5902閲覧

dataGridViewのチェック列(Boolean)のセルの値をTrueにした際、隣のセルを緑色にしたい。

ohikazuma

総合スコア9

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2020/03/10 06:09

前提・実現したいこと

開発環境:VS2015
言語等: C#, フォームアプリ

発生している問題・エラーメッセージ

dataGridViewのチェック列(Boolean)のセルの値をTrueにした瞬間(チェックマークが表示された直後)に、隣のセルを緑色にしたい。

該当のソースコード

下記コードで dataGridView を準備します。

//データテーブルの準備
DataTable dt = new DataTable();
DataRow dr;

//dtの定義
dt.Columns.Add("チェック", typeof(Boolean)); //Boolean!!!
dt.Columns.Add("販売店", typeof(String));
dt.Columns.Add("備考", typeof(String));

//値の代入
dr = dt.NewRow();
dr["チェック"] = false;   //初期値はFalse!
dr["販売店"] = "札幌";
dr["備考"] = "1980開設";
dt.Rows.Add(dr);

dr = dt.NewRow();
dr["チェック"] = false;   //初期値はFalse!
dr["販売店"] = "網走";
dr["備考"] = "2014開設";
dt.Rows.Add(dr);

dr = dt.NewRow();
dr["チェック"] = false;   //初期値はFalse!
dr["販売店"] = "函館";
dr["備考"] = "2009開設";
dt.Rows.Add(dr);

//dataGridView1にセット
dataGridView1.DataSource = dt;

試したこと

trueを確認し、セルの色を変えるコード↓

//全行チェックし、trueなら緑にする。
for (int i = 0; i < dataGridView1.RowCount; i++)
{
if ((Boolean)dataGridView1.Rows[i].Cells[0].Value == true)
{
dataGridView1.Rows[i].Cells[1].Style.BackColor = Color.LightGreen;
}
else
{
dataGridView1.Rows[i].Cells[1].Style.BackColor = Color.White;
}
}

これを、
dataGridView営業所_Click
dataGridView営業所_CellValueChanged
dataGridView営業所_CellContentClick
dataGridView営業所_CellMouseClick
dataGridView営業所_MouseUp
など様々なイベントに書き込みまいたが、
どれも他のセルを選択した際に、目的のセルが緑色になります。

根本的に間違っているのでしょうか?
宜しくお願いします。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

izmktr

2020/03/10 06:50

ざっと見る限り、うまく動くはずですが… 悩んでいるポイントが良くわかりません 理想はAだが、現状はBの動作をする、というふうにもっと具体的にかけますか?
ohikazuma

2020/03/10 07:04

【理想】 セルのチェック用□をクリックし、チェックが表示された瞬間に、隣のセルが緑になる。 【現状】 セルのチェック用□をクリックし、チェックが表示されるが、隣のセルの色は変わらない。 次に別のセルをクリックすると、目的のセルが緑になる …となります。 dataGridViewの表示が完了して、最後に走るイベントがあればよいのかも?
guest

回答2

0

ベストアンサー

他の方の回答にもありますが、チェックボックス型のセルをポチポチとクリックしても値は変更されず、別のセルを選択した際にはじめて値が確定します。
これを、別のセルを選択しなくても値を確定したい場合、DataGridView.CommitEdit を呼ぶ必要があります。


ということで、こんな感じでどうでしょうか。

csharp

1private void dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e) 2{ 3 // 0番目の列のみ処理対象とする 4 if (dataGridView1.CurrentCell.ColumnIndex != 0) return; 5 6 // 値を確定する 7 dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit); 8} 9 10private void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e) 11{ 12 // 0番目の列のみ処理対象とする 13 if (e.ColumnIndex != 0) return; 14 15 var cellValue = dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex].Value; 16 if (cellValue is Boolean) 17 { 18 if ((Boolean)cellValue) 19 { 20 dataGridView1.Rows[e.RowIndex].Cells[1].Style.BackColor = Color.LightGreen; 21 } 22 else 23 { 24 dataGridView1.Rows[e.RowIndex].Cells[1].Style.BackColor = Color.White; 25 } 26 } 27}

投稿2020/03/10 07:27

alg

総合スコア2019

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

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

ohikazuma

2020/03/10 08:26

algさん、ありがとうございました! 出来ました! 「チェックマークが表示されていも内部の値は変わっていない…」という訳ですね。 かなり検索したのですが見つかりませんでした。 助かりました。
guest

0

チェックを付けただけでは、dataGridViewは値を変更しません
別のセルに移動した瞬間に、dataGridView1.Rows[i].Cells[0].Valueの値へ反映されます

詳しくは、こちらが参考になると思います
https://dobon.net/vb/dotnet/datagridview/datagridviewcheckboxcolumn.html

投稿2020/03/10 07:13

izmktr

総合スコア2856

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

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

ohikazuma

2020/03/10 08:30

izmktrさん、情報ありがとうございました! dobonさんにも解説があったのですね、ここには行着けませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問