[Okta Webinar] Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1429
  • Last Modified:

How to put datagridview column in edit mode

I have a bound datagridview.  I would like to have the user click a button that would put one entire column into edit mode.  Let the user go down the rows editing this column, then click a button to save the new data to the grid and then datasource.  I can get current cell in edit mode but not sure how to do a column.
0
mgmhicks
Asked:
mgmhicks
3 Solutions
 
Roshan DavisCommented:
the following link has multi-row editing. Some changes to this code would work for entire column
http://www.dotnetjohn.com/articles.aspx?articleid=83
0
 
williamcampbellCommented:
You could Fake the Column Selection by Hi-Lighting the rectangle. Then as Each Item is clicked or the User uses the arrow you can select the row for editing. To only edit the Cell in the column you will have to turn of 'editability' for the other cells. I think this is a property of the Cell.

The Code Snippet below does the 'fake' hilighting

In the DataGrid MouseDown Event you will  find out if you have selected a column header through the hit test. You then find the co-ordinate of the column and construct a rectangle out of that. If you are selecting multiple columns you can store the index of the columns and the rectangle in  ArrayList.

Make sure you clear the ArrayList when you HitType is None.
protected void dataGrid1_MouseDown (object sender, System.Windows.Forms.MouseEventArgs e)
{
m_HitTest = dataGrid1.HitTest(e.X,e.Y);
if ( m_HitTest.Type == DataGrid.HitTestType.ColumnHeader )
{
int xCoordinate = this.GetLeftmostColumnHeaderXCoordinate( m_HitTest.Column );
int yCoordinate = this.GetTopmostColumnHeaderYCoordinate( e.X, e.Y );
int columnWidth = dataGrid1.TableStyles[0].GridColumnStyles
m_HitTest.Column].Width;
int columnHeight = this.GetColumnHeight( yCoordinate );
columnRegion = new Rectangle( xCoordinate, yCoordinate, columnWidth, columnHeight );
m_RectangleOfSelectedColumns.Add(columnRegion);
m_IndexOfSelectedColumns.Add(m_HitTest.Column);
}
else if(m_HitTest.Type == DataGrid.HitTestType.None)
{
this.m_RectangleOfSelectedColumns.Clear();
m_IndexOfSelectedColumns.Clear();
this.dataGrid1.Refresh();
}
}

In the DataGrid paint method you just fill the rectangles you contructed before in MouseDown Event.

private void dataGrid1_Paint(object sender, PaintEventArgs e)
{
Graphics g = e.Graphics;
if (m_HitTest != null && m_HitTest.Type == DataGrid.HitTestType.ColumnHeader )
{
for (int i = 0; i < this.m_RectangleOfSelectedColumns.Count; i++)
{
Rectangle columnRegion = (Rectangle)m_RectangleOfSelectedColumns[i];
SolidBrush blackBrush = new SolidBrush( Color.FromArgb( 255, 0, 0, 0 ) );
SolidBrush darkGreyBrush = new SolidBrush( Color.FromArgb( 100, 229, 229, 229 ) );
Pen blackPen = new Pen( blackBrush, 1F );
g.FillRectangle( darkGreyBrush, columnRegion);
g.DrawRectangle( blackPen, columnRegion );
}
}
}

Open in new window

0
 
sureshchsahuCommented:
The following link has complete code for the "Q" that you asked for:

http://www.codeproject.com/KB/webforms/SetEntireDataGridColumnEd.aspx
0
 
mgmhicksAuthor Commented:
Thanks guys, all solutions were different ways to handle this, but all are pretty complicated, so I approached the problem just editing the traditional way.  
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now