.NET TIPS DataGridViewコントロールで特定の値のセルを強調表示するには?[2.0のみ、C#、VB]デジタルアドバンテージ 遠藤 孝信2006/10/20 |
|
|
DataGridViewコントロールでは、特定の値を含むセルを色を変えるなどして強調表示したい場合がある。例えば数値を表示しているセルで、その値がマイナスであれば数字を赤色で表示するといった場合だ。
次の画面は「Encoder」という文字列が含まれている2列目のセルについて、その文字列を赤色で強調表示している例だ。
特定の文字列を含むセルを強調表示するDataGridViewコントロール |
この例では、「Encoder」という文字列が含まれているセルの文字を赤色で強調表示している。ここではセルが選択されている場合でも文字が赤色になるようにしている。 |
この画面のように、個々のセルの値に従ってその表示を変更したい場合には、個々のセルについて、それが表示される前に発生するCellFormattingイベントを利用すればよい。本来このイベントは、特定の値を持つセルに独自の書式を適用するためのものだが、値あるいは書式はそのままでセルのスタイルだけを変更することもできる。
CellFormattingイベント・ハンドラでは、メソッドの第2パラメータで渡されるDataGridViewCellFormattingEventArgsオブジェクト(System.Windows.Forms名前空間)から、そのセルの現在のスタイル(CellStyleプロパティ)やセルの値(Valueプロパティ)を取得/設定できる。これにより、セルの値をチェックしてから、そのスタイルを変更するといったことが可能だ。
また、イベントが発生しているセルの位置は、同オブジェクトのColumnIndexプロパティとRowIndexプロパティから分かる。
以下にCellFormattingイベント・ハンドラを記述したサンプル・プログラムを示す。上記のDataGridViewコントロールの画面はこれを実行したときのものだ。
| |
特定の値のセルを強調表示するC#のサンプル・プログラム(dgvcellformat.cs) | |
| |
特定の値のセルを強調表示するVBのサンプル・プログラム(dgvcellformat.vb) | |
ここではコードを簡便にするために、.NETで利用可能な画像のデコーダ一覧をデータソースとして使用している。画像のデコーダについては「TIPS:画像を読み込むには?」を参照してほしい。
なおすでに述べたように、CellFormattingイベントはすべてのセルに対して発生するため、特に列を限定せずにすべてのセルに対して処理を行うような場合には、現在処理中のセル(あるいはそのセルが含まれている列)の型に応じたセル値のキャストや、セル値のnullチェックなどが必要となることがあるので注意してほしい。
利用可能バージョン:.NET Framework 2.0のみ カテゴリ:Windowsフォーム 処理対象:DataGridViewコントロール 使用ライブラリ:DataGridViewコントロール 使用ライブラリ:DataGridViewCellFormattingEventArgsオブジェクト(System.Windows.Forms名前空間) |
「.NET TIPS」 |
- 第2回 簡潔なコーディングのために (2017/7/26)
ラムダ式で記述できるメンバの増加、throw式、out変数、タプルなど、C# 7には以前よりもコードを簡潔に記述できるような機能が導入されている - 第1回 Visual Studio Codeデバッグの基礎知識 (2017/7/21)
Node.jsプログラムをデバッグしながら、Visual Studio Codeに統合されているデバッグ機能の基本の「キ」をマスターしよう - 第1回 明瞭なコーディングのために (2017/7/19)
C# 7で追加された新機能の中から、「数値リテラル構文の改善」と「ローカル関数」を紹介する。これらは分かりやすいコードを記述するのに使える - Presentation Translator (2017/7/18)
Presentation TranslatorはPowerPoint用のアドイン。プレゼンテーション時の字幕の付加や、多言語での質疑応答、スライドの翻訳を行える
|
|