System.Windows.Forms.DataGridViewCellContextMenuStripNeededEventArgs Class

Provides data for the DataGridView.CellContextMenuStripNeeded event.

See Also: DataGridViewCellContextMenuStripNeededEventArgs Members


public class DataGridViewCellContextMenuStripNeededEventArgs : DataGridViewCellEventArgs


The DataGridView.CellContextMenuStripNeeded event occurs only when the System.Windows.Forms.DataGridView control DataGridView.DataSource property is set or its DataGridView.VirtualMode property is true.

When you handle the DataGridView.CellContextMenuStripNeeded event, the shortcut menu that you specify in the handler is shown whenever the user right-clicks a cell. This is useful when you want to display shortcut menus determined by the current state or value of a cell.

The DataGridView.CellContextMenuStripNeeded event also occurs whenever the value of the DataGridViewCell.ContextMenuStrip property is retrieved, either programmatically or when the user right-clicks the cell.

You can use the DataGridViewCellEventArgs.ColumnIndex and DataGridViewCellEventArgs.RowIndex properties to determine the state or value of a cell, and use this information to set the DataGridViewCellContextMenuStripNeededEventArgs.ContextMenuStrip property. This property is initialized with the value of the cell DataGridViewCell.ContextMenuStrip property, which the event value overrides.

Handle the DataGridView.CellContextMenuStripNeeded event when working with large amounts of data to avoid the performance penalties of setting the cell DataGridViewCell.ContextMenuStrip value for multiple cells. For more information, see Best Practices for Scaling the Windows Forms DataGridView Control.

You can also specify shortcut menus for individual rows rather than individual cells by setting the row DataGridViewRow.ContextMenuStrip property or handling the System.Windows.Forms.DataGridView control's DataGridView.RowContextMenuStripNeeded event. The cell DataGridViewCell.ContextMenuStrip property setting overrides the row DataGridViewRow.ContextMenuStrip property setting, and the DataGridView.CellContextMenuStripNeeded event overrides both the DataGridView.RowContextMenuStripNeeded event and the row DataGridViewRow.ContextMenuStrip property setting. You can specify null for a cell shortcut menu, however, to prevent a row shortcut menu from being overridden.

For more information about handling events, see Consuming Events.


Namespace: System.Windows.Forms
Assembly: System.Windows.Forms (in System.Windows.Forms.dll)
Assembly Versions:
Since: .NET 2.0