DataGridViewCell.InitializeEditingControl Метод

Определение

Инициализирует элемент управления, используемый для изменения ячейки.

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)

Параметры

rowIndex
Int32

Отсчитываемый с нуля индекс строки, в которой находится ячейка.

initialFormattedValue
Object

Объект Object, который представляет значение, отображаемое ячейкой при запуске редактирования.

dataGridViewCellStyle
DataGridViewCellStyle

Объект DataGridViewCellStyle, представляющий стиль ячейки.

Исключения

Связанные объекты DataGridView отсутствуют или если присутствует один такой объект, он не имеет связанного элемента управления "Поле ввода".

Примеры

В следующем примере кода показано, как переопределить InitializeEditingControl метод в простом классе, производном от DataGridViewTextBoxCell класса. Этот пример является частью более крупного примера кода, представленного в разделе "Практическое руководство. Размещение элементов управления в ячейках Windows Forms 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

Комментарии

В качестве метода оптимизации, как правило, все ячейки одного типа и в одной и той же DataGridView общей папке одного размещенного элемента управления редактирования. Однако перед использованием элемента управления ячейкой его необходимо инициализировать InitializeEditingControl с помощью метода. При первом вызове этот метод добавляет элемент управления в список элементов управления редактирования в родительском элементе DataGridViewуправления. Он также инициализирует некоторые визуальные свойства ячейки. Например, InitializeEditingControl задает цвет фона области редактирования в соответствии с заданным параметром стиля ячейки. Последующие вызовы ничего не делают InitializeEditingControl .

Производные классы используют этот метод для размещения экземпляра класса, Control соответствующего их типу. Например, таблица, содержащая один или несколько DataGridViewTextBoxCell объектов, вызывает этот метод для добавления одного TextBox элемента управления редактирования в владение DataGridView.

Применяется к

См. также раздел