DataGridViewCell.InitializeEditingControl(Int32, Object, DataGridViewCellStyle) メソッド

定義

セルの編集に使用されるコントロールを初期化します。Initializes the control used to edit the cell.

public:
 virtual void InitializeEditingControl(int rowIndex, System::Object ^ initialFormattedValue, System::Windows::Forms::DataGridViewCellStyle ^ dataGridViewCellStyle);
public virtual void InitializeEditingControl (int rowIndex, object initialFormattedValue, System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle);
abstract member InitializeEditingControl : int * obj * System.Windows.Forms.DataGridViewCellStyle -> unit
override this.InitializeEditingControl : int * obj * System.Windows.Forms.DataGridViewCellStyle -> unit

パラメーター

rowIndex
Int32

セルの位置の 0 から始まる行インデックス番号。The zero-based row index of the cell's location.

initialFormattedValue
Object

編集の開始時にセルに表示される値を表す ObjectAn Object that represents the value displayed by the cell when editing is started.

dataGridViewCellStyle
DataGridViewCellStyle

セルのスタイルを表す DataGridViewCellStyleA DataGridViewCellStyle that represents the style of the cell.

例外

関連付けられた DataGridView がありません。存在する場合は、関連付けられた編集コントロールがありません。There is no associated DataGridView or if one is present, it does not have an associated editing control.

次のコード例は、DataGridViewTextBoxCell クラスから派生した単純なクラスの InitializeEditingControl メソッドをオーバーライドする方法を示しています。The following code example demonstrates how to override the InitializeEditingControl method in a simple class that derives from the DataGridViewTextBoxCell class. この例は 次の方法で提供されるより大きなコード例の一部です。DataGridView セルWindows フォームのコントロールをホストします。This example is part of a larger code example provided in How to: Host Controls in Windows Forms DataGridView Cells.

public class CalendarCell : DataGridViewTextBoxCell
{

    public CalendarCell()
        : base()
    {
        // Use the short date format.
        this.Style.Format = "d";
    }

    public override void InitializeEditingControl(int rowIndex, object 
        initialFormattedValue, DataGridViewCellStyle dataGridViewCellStyle)
    {
        // Set the value of the editing control to the current cell value.
        base.InitializeEditingControl(rowIndex, initialFormattedValue, 
            dataGridViewCellStyle);
        CalendarEditingControl ctl = 
            DataGridView.EditingControl as CalendarEditingControl;
        // Use the default row value when Value property is null.
        if (this.Value == null)
        {
            ctl.Value = (DateTime)this.DefaultNewRowValue;
        }
        else
        {
            ctl.Value = (DateTime)this.Value;
        }
    }

    public override Type EditType
    {
        get
        {
            // Return the type of the editing control that CalendarCell uses.
            return typeof(CalendarEditingControl);
        }
    }

    public override Type ValueType
    {
        get
        {
            // Return the type of the value that CalendarCell contains.
            
            return typeof(DateTime);
        }
    }

    public override object DefaultNewRowValue
    {
        get
        {
            // Use the current date and time as the default value.
            return DateTime.Now;
        }
    }
}
Public Class CalendarCell
    Inherits DataGridViewTextBoxCell

    Public Sub New()
        ' Use the short date format.
        Me.Style.Format = "d"
    End Sub

    Public Overrides Sub InitializeEditingControl(ByVal rowIndex As Integer, _
        ByVal initialFormattedValue As Object, _
        ByVal dataGridViewCellStyle As DataGridViewCellStyle)

        ' Set the value of the editing control to the current cell value.
        MyBase.InitializeEditingControl(rowIndex, initialFormattedValue, _
            dataGridViewCellStyle)

        Dim ctl As CalendarEditingControl = _
            CType(DataGridView.EditingControl, CalendarEditingControl)

        ' Use the default row value when Value property is null.
        If (Me.Value Is Nothing) Then
            ctl.Value = CType(Me.DefaultNewRowValue, DateTime)
        Else
            ctl.Value = CType(Me.Value, DateTime)
        End If
    End Sub

    Public Overrides ReadOnly Property EditType() As Type
        Get
            ' Return the type of the editing control that CalendarCell uses.
            Return GetType(CalendarEditingControl)
        End Get
    End Property

    Public Overrides ReadOnly Property ValueType() As Type
        Get
            ' Return the type of the value that CalendarCell contains.
            Return GetType(DateTime)
        End Get
    End Property

    Public Overrides ReadOnly Property DefaultNewRowValue() As Object
        Get
            ' Use the current date and time as the default value.
            Return DateTime.Now
        End Get
    End Property

End Class

注釈

最適化の手法として、通常は同じ型のすべてのセルと同じ DataGridView 内のすべてのセルが、1つのホストされる編集コントロールを共有します。As an optimization technique, typically all the cells of the same type and in the same DataGridView share a single hosted editing control. ただし、セルによってコントロールが使用される前に、InitializeEditingControl メソッドによってコントロールを初期化する必要があります。However, before the control is used by a cell, it needs to be initialized by the InitializeEditingControl method. このメソッドが初めて呼び出されたときに、その親 DataGridView内の編集コントロールの一覧にコントロールが追加されます。The first time it is called, this method adds the control to the list of editing controls in its parent DataGridView. また、セルの一部のビジュアルプロパティも初期化します。It also initializes some of the visual properties of the cell. たとえば、InitializeEditingControl は、指定されたセルスタイルパラメーターと一致するように編集領域の背景色を設定します。For example, InitializeEditingControl sets the background color of the editing area to match the supplied cell style parameter. 後続の InitializeEditingControl を呼び出すと、何も行われません。Subsequent calls to InitializeEditingControl do nothing.

派生クラスは、このメソッドを使用して、その型に対応する Control クラスのインスタンスをホストします。Derived classes use this method to host an instance of the Control class corresponding to their type. たとえば、1つ以上の DataGridViewTextBoxCell オブジェクトを含むテーブルでは、このメソッドを呼び出して、所有している DataGridViewに1つの TextBox 編集コントロールを追加します。For example, a table that contains one or more DataGridViewTextBoxCell objects calls this method to add a single TextBox editing control to the owning DataGridView.

適用対象

こちらもご覧ください