У меня есть DataGridView, в котором я устанавливаю DataSource для коллекции объектов, когда выбрана вкладка DataGridView.
После того, как источник данных задан, я бы хотел изменить столбец "County" на DataGridViewComboBoxColumn с графствами штата в качестве элементов. Ничего из того, что я видел, пока не работает - оно всегда дает исключение.
Есть ли способ изменить тип столбца, не удаляя его?
Есть ли способ отображения комбинированного списка или другого элемента управления, когда я щелкаю ячейку в этой строке, не изменяя тип столбца?
======================== Мой код ошибки =================== ====
//ii is a for loop variable on the dataGridViewFields.Columns.Count
string colName = dataGridViewFields.Columns[ii].Name;
if (colName.Equals("County"))
{
string dpName = dataGridViewFields.Columns[ii].DataPropertyName;
DataGridViewComboBoxColumn column = new DataGridViewComboBoxColumn();
//get current column characteristics.
column.ValueType = dataGridViewFields.Columns[ii].ValueType; ;
column.Name = dataGridViewFields.Columns[ii].Name;
column.HeaderText = dataGridViewFields.Columns[ii].HeaderText;
column.Width = dataGridViewFields.Columns[ii].Width;
//remove column from grid
dataGridViewFields.Columns.RemoveAt(ii);
//set column combobox characteristics
column.DropDownWidth = 160;
column.MaxDropDownItems = 10;
column.Items.AddRange(new string[] {"Dane", "Dodge", "Door"});
column.FlatStyle = FlatStyle.Flat;
DataGridViewCell cell = new DataGridViewComboBoxCell();
cell.Style.BackColor = Color.Wheat;
cell.ValueType = typeof(string);
cell.Value = "Door";
column.CellTemplate = cell;
//add to the grid.
dataGridViewFields.Columns.Insert(ii, column);
dataGridViewFields.Columns[ii].DataPropertyName = dpName;
//dataGridViewFields.EditMode = DataGridViewEditMode.EditProgrammatically;
}