![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
質問させていただきます。
現在、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)
-
VB.NET DataGridView 縦スクロールバーを常に表示
Visual Basic(VBA)
-
-
4
データグリッドビューの一番最初の行に列を追加したい
Visual Basic(VBA)
-
5
文字列の後ろから必要分だけ削除したい。
Visual Basic(VBA)
-
6
VB.NET2005 TextBox 高さ(Height) 変更
Visual Basic(VBA)
-
7
GridViewにバインドせずにデータを表示する方法
Microsoft ASP
-
8
DataTableのselectメソッド
Microsoft ASP
-
9
DataGridViewのセルのItem設定につい
C言語・C++・C#
-
10
Ctrl + Cなど複数の入力キーの感知
Visual Basic(VBA)
-
11
コンボボックスのマウスホイールを無効にしたい
Visual Basic(VBA)
-
12
VB.net 重複チェックがしたいです
Visual Basic(VBA)
-
13
[VB.net] DataGridViewの列ヘッダー複数行表示に伴う不具合?について
Visual Basic(VBA)
-
14
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
マクロ 特定のセル値のみクリ...
-
Excel vba ユーザーフォームテ...
-
変数に代入してある数値を表示...
-
Dateserialで データ抽出
-
Excel VBA 複数選択したリスト...
-
VBでBtrieveファイルにアクセス...
-
ユーザーフォームの入力をシー...
-
マクロで奇数と偶数の値を2か所...
-
C#の質問です
-
DataTableに対するLINQについて
-
シーケンサで最小値を保持する
-
VBA ドロップダウンリストを残...
-
テキストボックスの設定。
-
COBOLの条件式について
-
エクセルVBAでコンボボックスの...
-
marginとpaddingにマイナス
-
VBプログラム エラーが出ます
-
VB.NETでコンボボックスの1行目...
-
windowsアプリケーションで小数...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
ハッシュテーブル(連想配列)が...
-
Excel VBAのリストボックスの値...
-
マクロ 特定のセル値のみクリ...
-
PysimpleGUIでデータベースを作る
-
VB.NETでコンボボックスの1行目...
-
変数名の取得
-
power BI クエリエディター 〇...
-
VB初心者。小数点以下の表示で...
-
PL/SQLでのTO_DATEの時間取得に...
-
【C++/CLI.NET】コンボボックス...
-
値を返さないコード パス
-
Powershellのparamについて
-
Excel VBA 複数選択したリスト...
-
DataTableに対するLINQについて
-
ユーザーフォームのテキストボ...
-
C# get set
-
変数に代入してある数値を表示...
-
VBAでWEB上の入力項目に値をい...
-
VB.NETでアクティブなformを知...
おすすめ情報