
リッチテキスト型セル(RichTextBoxCell)は、.NET FrameworkのRichTextBoxコントロール(System.Windows.Forms.RichTextBox)と同等の機能を提供します。RichTextBoxCellを使用すると、ユーザーはセルに書式付のテキストを直接入力できます。
 機能 
 データ型 
RichTextBoxCellはObject型の値を保持します。この型はRichTextBoxCell.ValueTypeプロパティで確認できます。
入力と表示には、String型にキャストした値が使用されます。この型はRichTextBoxCell.FormattedValueTypeプロパティで確認できます。Object型のToStringメソッドをオーバーライドすると、キャストする際の動作を変更できます。セルに値が読み出される場合の動作を変更するには、RichTextBoxCell.OnCellFormattingメソッドをオーバーライドします。セルから値が書き戻される場合の動作を変更するには、RichTextBoxCell.OnCellParsingメソッドをオーバーライドします。
入力と表示には、String型にキャストした値が使用されます。この型はRichTextBoxCell.FormattedValueTypeプロパティで確認できます。Object型のToStringメソッドをオーバーライドすると、キャストする際の動作を変更できます。セルに値が読み出される場合の動作を変更するには、RichTextBoxCell.OnCellFormattingメソッドをオーバーライドします。セルから値が書き戻される場合の動作を変更するには、RichTextBoxCell.OnCellParsingメソッドをオーバーライドします。
 セル編集コントロール 
RichTextBoxCellの値はRichTextBoxEditingControlコントロールで編集できます。このコントロールはIEditingControlインタフェースとSystem.Windows.Forms.RichTextBoxクラスを継承しています。セル編集コントロールの型はRichTextBoxCell.EditTypeプロパティで確認できます。 
 スタイル 
RichTextBoxCellはCellStyleクラスの次のメンバをサポートしています。セルのスタイルはRichTextBoxCell.Styleプロパティで設定します。
| CellStyleメンバ | 非編集時 | 編集時 | 
|---|---|---|
| BackColor | 有効 | 有効 | 
| BackgroundGradientEffect | 有効 | - | 
| Border | 有効 | 有効 | 
| DataSourceNullValue | 有効 | 有効 | 
| DisabledBackColor | 有効 | - | 
| DisabledForeColor | - | - | 
| DisabledGradientEffect | 有効 | - | 
| EditingBackColor | - | 有効 | 
| EditingForeColor | - | - | 
| Font | - | - | 
| ForeColor | - | - | 
| Format | 有効 | 有効 | 
| FormatProvider | 有効 | 有効 | 
| Image | - | - | 
| ImageAlign | - | - | 
| ImeMode | 有効 | 有効 | 
| ImeSentenceMode | 有効 | 有効 | 
| InputScope | 有効 | 有効 | 
| LineAdjustment | 有効 | - | 
| Margin | 有効 | 有効 | 
| MouseOverBackColor | 有効 | - | 
| MouseOverForeColor | - | - | 
| MouseOverGradientEffect | 有効 | - | 
| Multiline | 有効 | 有効 | 
| NullValue | 有効 | 有効 | 
| Padding | 有効 | 有効 | 
| PatternColor | 有効 | - | 
| PatternStyle | 有効 | - | 
| SelectionBackColor | 有効 | - | 
| SelectionForeColor | - | - | 
| SelectionGradientEffect | 有効 | - | 
| Tag | 有効 | 有効 | 
| TextAdjustment | - | - | 
| TextAlign | - | - | 
| TextAngle | - | - | 
| TextEffect | - | - | 
| TextImageRelation | - | - | 
| TextIndent | - | - | 
| TextVertical | - | - | 
| UseCompatibleTextRendering | - | - | 
| WordWrap | 有効 | 有効 | 
- RichTextBoxCellではCellStyle.MultiLineプロパティの既定値はMultiRowTriState.Trueです。
- GDI+互換モードを有効にするには、RichTextBoxCell.Style.UseCompatibleTextRenderingプロパティをTrueに設定します。
 ショートカットキー 
次の表はRichTextBoxCellの編集時に処理されるキーと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.Control+Keys.Cは、複数のセルが選択されている場合はGcMultiRowコントロールによって処理されます。
- Keys.PageDownとKeys.PageUpは、RichTextBoxCellの値が変更されていない場合はGcMultiRowコントロールによって処理されます。
- Keys.LeftはRichTextBoxCellのキャレットが先頭の文字よりも前にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.RightはRichTextBoxCellのキャレットが最後の文字よりも後ろにあるとき、GcMultiRowコントロールによって処理されます。
- Keys.UpはRichTextBoxCellのキャレットが最初の行にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.DownはRichTextBoxCellのキャレットが最後の行にあるとき、GcMultiRowコントロールによって処理されます。
- Keys.UpとKeys.Downは、RichTextBoxCellが複数行を許可しない場合はGcMultiRowコントロールによって処理されます。
 イベント 
セルの内容領域のクリックに対応した処理を実装するには、GcMultiRow.CellContentClickイベントを使用します。ダブルクリックの場合はGcMultiRow.CellContentDoubleClickイベントです。
セルの値が変更されたときの処理を実装するには、GcMultiRow.CellEditedFormattedValueChangedイベントを使用します。
RichTextBoxCellを編集中のイベントに対応した処理は、RichTextBoxEditingControlクラスのイベントを使用します。
    セルの値が変更されたときの処理を実装するには、GcMultiRow.CellEditedFormattedValueChangedイベントを使用します。
RichTextBoxCellを編集中のイベントに対応した処理は、RichTextBoxEditingControlクラスのイベントを使用します。