TableLayoutPanel.SetColumn Method (Control, Int32)


The .NET API Reference documentation has a new home. Visit the .NET API Browser on to see the new experience.

Sets the column position of the specified child control.

Namespace:   System.Windows.Forms
Assembly:  System.Windows.Forms (in System.Windows.Forms.dll)

public void SetColumn(
	Control control,
	int column


Type: System.Windows.Forms.Control

The control to move to another column.

Type: System.Int32

The column to which control will be moved.

The SetColumn method moves the control to another column in the TableLayoutPanel. The columns and rows have zero-based indexes. Setting the column position to -1 specifies that the control will flow to the first empty cell.

This method reapplies the table layout to all controls in the TableLayoutPanel.

This method is called by the Column property, which the panel adds to its child controls at design time.

The following code example uses the SetColumn method to swap two controls contained within a TableLayoutPanel control. The example assumes a TableLayoutPanel control with at least two rows.

  private void swapControlsBtn_Click(
System.Object sender, 
System.EventArgs e)
      Control c1 = this.TableLayoutPanel1.GetControlFromPosition(0, 0);
      Control c2 = this.TableLayoutPanel1.GetControlFromPosition(0, 1);

      if( c1 != null && c2 != null )
          this.TableLayoutPanel1.SetColumn(c2, 0);
          this.TableLayoutPanel1.SetColumn(c1, 1);

.NET Framework
Available since 2.0
Return to top