
文字列型セル(TextBoxCell)は、.NET FrameworkのTextBoxコントロール(System.Windows.Forms.TextBox)と同等の機能を提供します。TextBoxCellを使用すると、ユーザーはセルにテキストを直接入力できます。
機能
TextBoxCellでは、基本セルの機能に加えて、次の機能を使用できます。
各機能の詳細はTextBoxCellクラスのリファレンスを参照してください。
- テキストの表示と入力
- 複数行のテキストの入力
- テキストのワードラップ
- 読み取り専用のテキスト
- パスワード文字のマスク
- スクロールバーの表示
- コンテキスト メニューの表示
- イベント
各機能の詳細はTextBoxCellクラスのリファレンスを参照してください。
データ型
TextBoxCellはObject型の値を保持します。この型はTextBoxCell.ValueTypeプロパティで確認できます。
入力と表示には、String型にキャストした値が使用されます。この型はTextBoxCell.FormattedValueTypeプロパティで確認できます。Object型のToStringメソッドをオーバーライドすると、キャストする際の動作を変更できます。セルに値が読み出される場合の動作を変更するには、TextBoxCell.OnCellFormattingメソッドをオーバーライドします。セルから値が書き戻される場合の動作を変更するには、TextBoxCell.OnCellParsingメソッドをオーバーライドします。
入力と表示には、String型にキャストした値が使用されます。この型はTextBoxCell.FormattedValueTypeプロパティで確認できます。Object型のToStringメソッドをオーバーライドすると、キャストする際の動作を変更できます。セルに値が読み出される場合の動作を変更するには、TextBoxCell.OnCellFormattingメソッドをオーバーライドします。セルから値が書き戻される場合の動作を変更するには、TextBoxCell.OnCellParsingメソッドをオーバーライドします。
セル編集コントロール
TextBoxCellの値はTextBoxEditingControlコントロールで編集できます。このコントロールはIEditingControlインタフェースとSystem.Windows.Forms.TextBoxクラスを継承しています。セル編集コントロールの型はTextBoxCell.EditTypeプロパティで確認できます。
スタイル
TextBoxCellはCellStyleクラスの次のメンバをサポートしています。セルのスタイルはTextBoxCell.Styleプロパティで設定します。
GDI+互換モードを有効にするには、TextBoxCell.Style.UseCompatibleTextRenderingプロパティをTrueに設定します。
| CellStyleメンバ | 非編集時 | 編集時 |
|---|---|---|
| BackColor | 有効 | 有効 |
| BackgroundGradientEffect | 有効 | - |
| Border | 有効 | 有効 |
| DataSourceNullValue | 有効 | 有効 |
| DisabledBackColor | 有効 | - |
| DisabledForeColor | 有効 | - |
| DisabledGradientEffect | 有効 | - |
| EditingBackColor | - | 有効 |
| EditingForeColor | - | 有効 |
| Font | 有効 | 有効 |
| ForeColor | 有効 | 有効 |
| Format | 有効 | 有効 |
| FormatProvider | 有効 | 有効 |
| Image | 有効 | - |
| ImageAlign | 有効 | - |
| ImeMode | 有効 | 有効 |
| ImeSentenceMode | 有効 | 有効 |
| InputScope | 有効 | 有効 |
| LineAdjustment | GDI+互換モードの場合のみ有効 | - |
| Margin | 有効 | 有効 |
| MouseOverBackColor | 有効 | - |
| MouseOverForeColor | 有効 | - |
| MouseOverGradientEffect | 有効 | - |
| Multiline | 有効 | 有効 |
| NullValue | 有効 | 有効 |
| Padding | 有効 | 有効 |
| PatternColor | 有効 | - |
| PatternStyle | 有効 | - |
| SelectionBackColor | 有効 | - |
| SelectionForeColor | 有効 | - |
| SelectionGradientEffect | 有効 | - |
| Tag | 有効 | 有効 |
| TextAdjustment | GDI+互換モードの場合のみ有効 | - |
| TextAlign | 有効 | 水平方向のみ |
| TextAngle | GDI+互換モードの場合のみ有効 | - |
| TextEffect | 有効 | - |
| TextImageRelation | 有効 | - |
| TextIndent | 有効 | - |
| TextVertical | GDI+互換モードの場合のみ有効 | - |
| UseCompatibleTextRendering | 有効 | - |
| WordWrap | 有効 | 有効 |
GDI+互換モードを有効にするには、TextBoxCell.Style.UseCompatibleTextRenderingプロパティをTrueに設定します。
ショートカットキー
次の表はTextBoxCellの編集時に処理されるキーとGcMultiRowコントロールで処理されるキーの一覧です。
| 修飾子 | キー | 文字列型セル | GcMultiRow |
|---|---|---|---|
| なし | Keys.PageUp | 有効 | - |
| Keys.PageDown | 有効 | - | |
| Keys.End | 有効 | - | |
| Keys.Home | 有効 | - | |
| Keys.Left | 有効 | - | |
| Keys.Right | 有効 | - | |
| Keys.Up | 有効 | - | |
| Keys.Down | 有効 | - | |
| Keys.Insert | - | - | |
| Keys.Delete | 有効 | - | |
| Keys.BackSpace | 有効 | - | |
| Keys.Control | Keys.PageUp | - | - |
| Keys.PageDown | - | - | |
| Keys.End | 有効 | - | |
| Keys.Home | 有効 | - | |
| Keys.Left | 有効 | - | |
| Keys.Right | 有効 | - | |
| Keys.Up | - | 有効 | |
| Keys.Down | - | 有効 | |
| Keys.A | 有効 | - | |
| Keys.C | 有効 | - | |
| Keys.V | 有効 | - | |
| Keys.X | 有効 | - | |
| Keys.Shift | Keys.Left | 有効 | - |
| Keys.Right | 有効 | - | |
| Keys.Up | 有効 | - | |
| Keys.Down | 有効 | - | |
| Keys.Home | 有効 | - | |
| Keys.End | 有効 | - | |
| Keys.Enter | 複数行の場合のみ有効 | - | |
| Keys.F10 | 有効 | - |
- Keys.Control+Keys.Cは、複数のセルが選択されている場合はGcMultiRowコントロールによって処理されます。
- Keys.PageDownとKeys.PageUpは、TextBoxCellの値が変更されていない場合はGcMultiRowコントロールによって処理されます。
- Keys.LeftはTextBoxCellのキャレットが先頭の文字よりも前にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.RightはTextBoxCellのキャレットが最後の文字よりも後ろにあるとき、GcMultiRowコントロールによって処理されます。
- Keys.UpはTextBoxCellのキャレットが最初の行にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.DownはTextBoxCellのキャレットが最後の行にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.UpとKeys.Downは、TextBoxCellが複数行を許可しない場合はGcMultiRowコントロールによって処理されます。
イベント
セルの内容領域のクリックに対応した処理を実装するには、GcMultiRow.CellContentClickイベントを使用します。ダブルクリックの場合はGcMultiRow.CellContentDoubleClickイベントです。
セルの値が変更されたときの処理を実装するには、GcMultiRow.CellEditedFormattedValueChangedイベントを使用します。
TextBoxCellを編集中のイベントに対応した処理は、TextBoxEditingControlクラスのイベントを使用します。
セルの値が変更されたときの処理を実装するには、GcMultiRow.CellEditedFormattedValueChangedイベントを使用します。
TextBoxCellを編集中のイベントに対応した処理は、TextBoxEditingControlクラスのイベントを使用します。
標準コントロールとの比較
次の表はTextBoxCellとSystem.Windows.Forms.TextBoxコントロール、System.Windows.Forms.DataGridViewTextBoxCellクラスの主要なプロパティの比較です。
| TextBoxCell | TextBox | DataGridViewTextBoxCell |
|---|---|---|
| なし | AcceptsReturns | なし |
| なし | AutoCompleteCustomSource | なし |
| なし | AutoCompleteMode | なし |
| なし | AutoCompleteSource | なし |
| Style.BackColor | BackColor | Style.BackColor |
| CharacterCasing | CharacterCasing | なし |
| Style.ForeColor | ForeColor | Style.ForeColor |
| MaxLength | MaxLength | MaxInputLength |
| Style.MultiLine | MultiLine | なし |
| PasswordChar | PasswordChar | なし |
| ScrollBars | ScrollBars | なし |
| Value | Text | Value |
| Style.TextAlign | TextAlign | Style.Alignment |
| UseSystemPasswordChar | UseSystemPasswordChar | なし |
| Style.WordWrap | WordWrap | Style.WrapMode |
使用例