前回作成したサンプルに、ヘッダー行でフィルタする機能を加えました。
ソースコードは GitHub で公開しています。
フィルタの選択肢にリストアップされている「昇順で並べ替え、降順で並べ替え、全て選択、空白セル、空白以外のセル」と重複排除したセル値のリストアップ、フィルタを選択した際の挙動は、GcMultiRowの標準機能なので実装不要です。
ソースコードの変更点
data:image/s3,"s3://crabby-images/3e02d/3e02d1b42e4c7e9e381372823a024dd0a4d9ef4b" alt=""
MyDataModel.cs
GcMultiRowコントロールとバインドするデータクラスを追加。
data:image/s3,"s3://crabby-images/f0ed7/f0ed75165baea5f086966769272c45e41b8eda34" alt=""
1 2 3 4 5 6 7 |
internal class MyDataModel { public bool CheckBoxValue { get; set; } public string TextBoxValue { get; set; } } |
Form1.cs
「昇順で並べ替え、降順で並べ替え、全て選択、空白セル、空白以外のセル」選択肢を表示するオプションと、セルに表示/入力された値をフィルタに自動リストアップするオプションを trueにして、2列目のHeaderCell(TextBox Culoumn)にフィルタ追加。
data:image/s3,"s3://crabby-images/d61b3/d61b388634d687099c95a879714033ac99117de0" alt=""
1 2 3 |
DropDownList = new HeaderDropDownList(1, true, true) |
データクラスのインスタンスをバインド。
データクラスをバインドしないとGcMultiRowのフィルタは機能しません。
1 2 3 4 5 6 7 8 9 |
var data = new BindingList<MyDataModel> { new MyDataModel { CheckBoxValue = true, TextBoxValue = "Text data 1" }, new MyDataModel { CheckBoxValue = false, TextBoxValue = "Text data 2" } }; GcMultiRow1.DataSource = data; |
データクラスのどの項目が、GcMultiRowコントロールのどの列と連動するのかを DataFieldで設定。
1 2 3 4 5 |
DataField = nameof(MyDataModel.CheckBoxValue) DataField = nameof(MyDataModel.TextBoxValue) |
data:image/s3,"s3://crabby-images/900bf/900bfdfd4830e9ee7cd56ae2e205df4e6f0dbc78" alt=""
コメント