DataGridViewCell.InitializeEditingControl Yöntem

Tanım

Hücreyi düzenlemek için kullanılan denetimi başlatır.

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);
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)

Parametreler

rowIndex
Int32

Hücrenin konumunun sıfır tabanlı satır dizini.

initialFormattedValue
Object

Object Düzenleme başlatılırken hücre tarafından görüntülenen değeri temsil eden bir.

dataGridViewCellStyle
DataGridViewCellStyle

DataGridViewCellStyle Hücrenin stilini temsil eden bir.

Özel durumlar

İlişkili DataGridView yok veya varsa, ilişkili bir düzenleme denetimi yoktur.

Örnekler

Aşağıdaki kod örneği, sınıfından InitializeEditingControl türetilen DataGridViewTextBoxCell basit bir sınıfta yönteminin nasıl geçersiz kılındığını gösterir. Bu örnek, Nasıl yapılır: Windows Forms DataGridView Hücrelerinde Denetimleri Barındırma bölümünde sağlanan daha büyük bir kod örneğinin parçasıdır.

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

Açıklamalar

İyileştirme tekniği olarak, genellikle aynı türdeki ve aynı DataGridView içindeki tüm hücreler tek bir barındırılan düzenleme denetimini paylaşır. Ancak, denetim bir hücre tarafından kullanılmadan önce yöntemi tarafından InitializeEditingControl başlatılması gerekir. İlk kez çağrıldığında, bu yöntem denetimi üst DataGridViewöğesindeki düzenleme denetimleri listesine ekler. Ayrıca hücrenin görsel özelliklerinden bazılarını başlatır. Örneğin, InitializeEditingControl düzenleme alanının arka plan rengini sağlanan hücre stili parametresiyle eşleşecek şekilde ayarlar. Hiçbir şey yapmak için InitializeEditingControl sonraki çağrılar.

Türetilmiş sınıflar, türlerine karşılık gelen sınıfın Control bir örneğini barındırmak için bu yöntemi kullanır. Örneğin, bir veya daha fazla DataGridViewTextBoxCell nesne içeren bir tablo, sahip DataGridViewolan öğesine tek TextBox bir düzenleme denetimi eklemek için bu yöntemi çağırır.

Şunlara uygulanır

Ayrıca bkz.