Udostępnij za pośrednictwem


DataGridViewCell.InitializeEditingControl Metoda

Definicja

Inicjuje kontrolkę używaną do edytowania komórki.

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
Public Overridable Sub InitializeEditingControl (rowIndex As Integer, initialFormattedValue As Object, dataGridViewCellStyle As DataGridViewCellStyle)

Parametry

rowIndex
Int32

Indeks wiersza na podstawie zera lokalizacji komórki.

initialFormattedValue
Object

Element Object reprezentujący wartość wyświetlaną przez komórkę podczas edytowania.

dataGridViewCellStyle
DataGridViewCellStyle

Obiekt DataGridViewCellStyle reprezentujący styl komórki.

Wyjątki

Brak skojarzenia DataGridView lub jeśli istnieje, nie ma skojarzonej kontrolki edytowania.

Przykłady

W poniższym przykładzie kodu pokazano, jak zastąpić metodę InitializeEditingControl w prostej klasie pochodzącej DataGridViewTextBoxCell z klasy . Ten przykład jest częścią większego przykładu kodu przedstawionego w temacie How to: Host Controls in Windows Forms DataGridView Cells (Instrukcje: kontrolki hosta w komórkach dataGridView).

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

Uwagi

Jako technika optymalizacji zwykle wszystkie komórki tego samego typu i w tym samym DataGridView udziale jednej hostowanej kontrolki edycji. Jednak zanim kontrolka zostanie użyta przez komórkę, musi zostać zainicjowana przez metodę InitializeEditingControl . Przy pierwszym wywołaniu ta metoda dodaje kontrolkę do listy kontrolek edycji w obiekcie nadrzędnym DataGridView. Inicjuje również niektóre właściwości wizualne komórki. Na przykład InitializeEditingControl ustawia kolor tła obszaru edycji, aby był zgodny z podanym parametrem stylu komórki. Kolejne połączenia, aby InitializeEditingControl nic nie robić.

Klasy pochodne używają tej metody do hostowania wystąpienia klasy odpowiadającej Control ich typowi. Na przykład tabela zawierająca co najmniej jeden DataGridViewTextBoxCell obiekt wywołuje tę metodę, aby dodać pojedynczą TextBox kontrolkę edycji do obiektu będącego właścicielem DataGridView.

Dotyczy

Zobacz też