質問させていただきます。
現在、VB.net2019を使用してシステムを製造しています。
DataGridViewのコンボボックスで、以下のことをしたいと考えています。
・入力値に対して「部分一致」で検索を行い、自身のリストから値を絞り込む
・リストにもない値も入力可能
絞り込みに関しては、オートコンプリート機能を用いると
前方一致で候補値が出てくるのはわかっているのですが、部分一致は行えません。
また、リストにない値を入力する方法だけはわかったのですが、
絞り込み機能と併用する必要があります。
現在、コンボボックスのリスト値はデータテーブルでセットしていますが、
Itemへの追加でも問題有りません。
上記の機能を実装するための手がかりを見つけられず
焦っています。
お手数をおかけしますが、よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
できません。
DataGridViewComboBoxColumn、DataGridViewComboBoxCell、DataGridViewComboBoxEditingControlを継承して、既存のAutoCompleteに頼らない実装を相当作り込まないと実現することはできません。
public class DataGridViewComboBoxColumnEx : DataGridViewComboBoxColumn
{
public DataGridViewComboBoxColumnEx() : base()
{
this.CellTemplate = new DataGridViewComboBoxCellEx();
}
}
public class DataGridViewComboBoxEditingControlEx : DataGridViewComboBoxEditingControl
{
protected override void OnEnter(EventArgs e)
{
base.OnEnter(e);
this.DropDownStyle = ComboBoxStyle.DropDown;
}
}
public class DataGridViewComboBoxCellEx : DataGridViewComboBoxCell
{
private Type editType = typeof(DataGridViewComboBoxEditingControlEx);
public override Type EditType => this.editType;
}
DataGridViewComboBoxEditingControlEx として、既存のドロップダウンの動作を強制的に廃止し、入力候補の絞り込みが行われるドロップダウンを描画することになりそうです。
ちょっと既存ドロップダウンを表示させない方法は分かりませんでした。
また、これを行うと、MessageFiliterを利用して、ドロップダウンが表示されている際に上、下、Esc、Tab、Enter、マウスホイール操作が行われた時にドロップダウン側にその操作を通知させる必要があります。
返信ありがとうございます。
簡単にはできないのですね。。。
おっしゃる通り、矢印やマウスの制御等もあるため
今から作りこむのは難しそうです。
見た目は既存の機能にかなわないとは思いますが
類似の動作を行えないか色々と試してみます。
既存の機能ではすぐにできないことがかわり
すっきりしました。
ご回答、ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP 「ログイン機能を持たせる」説明が気難しいです。 2 2022/10/11 02:59
- Excel(エクセル) CSVファイルがカンマ区切りにならない。対処法を教えていただきたいです。 仕事でSMS一斉送信ができ 2 2022/07/01 21:24
- Excel(エクセル) 【Excel】指定した文字列に該当する行を重複しないようにリスト 3 2022/03/30 12:27
- Word(ワード) LibreOfficeで数年保存しているデータの変更作業 4 2022/07/08 17:15
- Excel(エクセル) 別シートの表の値を参照したい 2 2022/03/30 15:11
- PHP PHPSpreadsheetを使って関数を繰り返し埋め込みたい 1 2023/05/24 11:33
- Visual Basic(VBA) VBAでの共有パスにつきまして 1 2023/03/04 17:24
- Java java 次の機能を有するメソッドを自クラスに作成し、実装したいです。 機能 名前判定機能 →名前が 3 2022/06/16 16:08
- その他(趣味・アウトドア・車) アマチュア無線の「村」まで入った「市郡区番号リスト」を探しています 4 2022/08/27 07:07
- ビデオカード・サウンドカード 1つのマザボでAMD&NVIDIAを同時使用できますか? 3 2022/04/22 14:36
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
データベースのデータをTextBoxに入力された値で検索しDataGridViewに表示する方法
Visual Basic(VBA)
-
【VB】タブ切り替え時のイベント
Visual Basic(VBA)
-
文字列の後ろから必要分だけ削除したい。
Visual Basic(VBA)
-
-
4
VB.NET DataGridView 縦スクロールバーを常に表示
Visual Basic(VBA)
-
5
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
6
有無、要否、賛否、是非、可否、当否…これらの言葉について
その他(教育・科学・学問)
-
7
FORMが開いているかどうかの確認方法
Visual Basic(VBA)
-
8
データグリッドビューの一番最初の行に列を追加したい
Visual Basic(VBA)
-
9
DataGridViewの特定列に入力されている重複チェックをしたい
Visual Basic(VBA)
-
10
C# ログイン画面からメイン画面への画面遷移について
C言語・C++・C#
-
11
DataGridViewのセルのItem設定につい
C言語・C++・C#
-
12
VB.NETで小数点以下の桁数を取得したい
その他(ソフトウェア)
-
13
DataTableのselectメソッド
Microsoft ASP
-
14
Ctrl + Cなど複数の入力キーの感知
Visual Basic(VBA)
-
15
C# dataGridViewの値だけクリア
C言語・C++・C#
-
16
DataGrdViewに関連付けたデータの更新
C言語・C++・C#
-
17
コンボボックスのマウスホイールを無効にしたい
Visual Basic(VBA)
-
18
VB.net 重複チェックがしたいです
Visual Basic(VBA)
-
19
[VB.net] DataGridViewの列ヘッダー複数行表示に伴う不具合?について
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
c++のタイマーについて
-
[VBA]選択範囲の下から上に処理...
-
VB.NETでコンボボックスの1行目...
-
Excel VBA 複数選択したリスト...
-
値を返さないコード パス
-
ハッシュテーブル(連想配列)が...
-
不定値の出力について
-
VBAでWEB上の入力項目に値をい...
-
Dbtypeって?
-
C#の質問です
-
他のformのコントロールの値の...
-
変数に代入してある数値を表示...
-
SqlParameterとSqlCommandの使...
-
シーケンサで最小値を保持する
-
ユーザーフォームのテキストボ...
-
C# get set
-
VB.netでRGB関数を使うには
-
マクロ 特定のセル値のみクリ...
-
VB.NETのスクロールバーコント...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
マクロ 特定のセル値のみクリ...
-
VB.NETでコンボボックスの1行目...
-
変数名の取得
-
値を返さないコード パス
-
Excel VBAのリストボックスの値...
-
VB初心者。小数点以下の表示で...
-
ハッシュテーブル(連想配列)が...
-
textboxとLabelを動的に変更する
-
PL/SQLでのTO_DATEの時間取得に...
-
VB.NETでアクティブなformを知...
-
Excel vba ユーザーフォームテ...
-
マクロで奇数と偶数の値を2か所...
-
DataTableに対するLINQについて
-
【C++/CLI.NET】コンボボックス...
-
[VBA]選択範囲の下から上に処理...
-
範囲が指定されている乱数について
-
[VB.net] DataGridViewのコンボ...
-
変数に代入してある数値を表示...
-
vbscriptを使いexcelを参照して...
おすすめ情報