DataGridViewCell.InitializeEditingControl Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Inicializa el control utilizado para editar la celda.
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)
Parámetros
- rowIndex
- Int32
Índice de base cero de la fila de la ubicación de la celda.
- initialFormattedValue
- Object
Object que representa el valor que muestra la celda cuando se inicia la edición.
- dataGridViewCellStyle
- DataGridViewCellStyle
DataGridViewCellStyle que representa el estilo de la celda.
Excepciones
No hay ningún control DataGridView asociado o, si alguno está presente, no tiene asociado un control de edición.
Ejemplos
En el ejemplo de código siguiente se muestra cómo invalidar el InitializeEditingControl método en una clase simple que deriva de la DataGridViewTextBoxCell clase . Este ejemplo forma parte de un ejemplo de código más grande que se proporciona en 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
Comentarios
Como técnica de optimización, normalmente todas las celdas del mismo tipo y en el mismo DataGridView comparten un único control de edición hospedado. Sin embargo, antes de que una celda use el control, debe inicializarse mediante el InitializeEditingControl método . La primera vez que se llama, este método agrega el control a la lista de controles de edición en su elemento primario DataGridView. También inicializa algunas de las propiedades visuales de la celda. Por ejemplo, InitializeEditingControl establece el color de fondo del área de edición para que coincida con el parámetro de estilo de celda proporcionado. Las llamadas posteriores para InitializeEditingControl no hacer nada.
Las clases derivadas usan este método para hospedar una instancia de la Control clase correspondiente a su tipo. Por ejemplo, una tabla que contiene uno o varios DataGridViewTextBoxCell objetos llama a este método para agregar un único TextBox control de edición al propietario DataGridViewde .