여러 행이 포함 된 TableLayoutPanel이 있는데 그 중 일부는 TextBox'es를 포함하고 일부는 DataGridView를 포함합니다. DataGridView의 AutoSize를 포함하는 TableLayoutPanel 행의 SizeType을 설정합니다. DataGridView에서 행을 추가/제거 할 때 해당 행을 포함하는 행의 높이가 증가/감소한다고 기대하고있었습니다. 그것은 일어나지 않습니다. 이것이 어떻게 작동해야하는지 오해하고 있습니까? 이 방법이 내가 예상했던대로 작동하도록 할 수 있습니까?TableLayoutPanel 조정 DataGridView에서 행을 추가/제거 할 때의 행 높이
0
A
답변
0
2 명의 의견 작성자가 맞았습니다. 문제는 DataGridView 자체에서 발생했습니다. 나는 method 1을 사용하여 끝났다. 여러 개의 탭이있는 테스트 응용 프로그램을 만들었고, 각 탭에는 datagridview와 행을 추가하는 버튼, 행을 제거하는 버튼이 포함되어 있습니다. 첫 번째 탭에는이 세 가지 구성 요소가 포함되어 있었으므로 실제로 확장 될 수 있는지 확인하고 싶었습니다. 두 번째 탭에서 Autoscroll이 true로 설정된 Panel 내부에 세 개의 구성 요소를 놓았습니다. 그것도 괜찮 았어. 그리고 계속해서, 사용자 정의 컨트롤 내에서 DataLabel 및 Button을 TableLayoutPanel 내에 놓을 때까지 (자동 스크롤을 true로 설정하여) 그것은 모두 잘 작동합니다. 다른 사람들이 실험하고 싶어하는 경우를 대비하여, 버튼을 두 개씩 누르고 데이터 그 림 뷰를 각 탭에 놓고 주 폼에서 다음 코드를 사용하여 디자이너를 사용하지 않고 초기화합니다.
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
Setup(dataGridView1, buttonAddRow1, buttonRemoveRow1);
Setup(dataGridView2, buttonAddRow2, buttonRemoveRow2);
Setup(dataGridView3, buttonAddRow3, buttonRemoveRow3);
Setup(dataGridView4, button1, button2);
Setup(userControl11.dataGridView4, userControl11.button1, userControl11.button2);
dataGridView3.MaximumSize = new Size(0, 100);
dataGridView4.MaximumSize = new Size(0, 100);
}
#region static helpers
private static void Setup(DataGridView grid, Button buttonAdd, Button buttonRemove)
{
BindingList<RowItem> list = new BindingList<RowItem>();
SetupGrid(grid, list);
buttonAdd.Click += (sender, e) => Add(list);
buttonRemove.Click += (sender, e) => Remove(list);
}
private static void Add(BindingList<RowItem> list)
{
list.Add(new RowItem() { Name = "Row " + list.Count });
}
private static void Remove(BindingList<RowItem> list)
{
if (list.Count > 0)
list.RemoveAt(list.Count - 1);
}
private static void SetupGrid(DataGridView grid, BindingList<RowItem> list)
{
grid.AutoGenerateColumns = false;
grid.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
grid.RowHeadersVisible = false;
grid.Columns.Add(CreateTextColumn("Name"));
grid.DataSource = list;
}
/// <summary>
/// Sets read-only to true
/// </summary>
/// <param name="dataPropertyName"></param>
/// <param name="format"></param>
/// <param name="columnName"></param>
/// <returns></returns>
static public DataGridViewTextBoxColumn CreateTextColumn(string dataPropertyName, string columnName = null, string format = null, bool readOnly = true, DataGridViewAutoSizeColumnMode autosizeMode = DataGridViewAutoSizeColumnMode.AllCells, int width = 40, DataGridViewColumnSortMode sortMode = DataGridViewColumnSortMode.Automatic)
{
DataGridViewTextBoxColumn textColumn = new DataGridViewTextBoxColumn();
textColumn.DataPropertyName = dataPropertyName;
textColumn.Name = String.IsNullOrEmpty(columnName) ? dataPropertyName : columnName;
textColumn.ReadOnly = readOnly;
textColumn.AutoSizeMode = autosizeMode;
textColumn.Resizable = DataGridViewTriState.True;
textColumn.Width = width;
if (!String.IsNullOrEmpty(format))
textColumn.DefaultCellStyle.Format = format;
textColumn.SortMode = sortMode;
return textColumn;
}
#endregion static helpers
}
class RowItem
{
public string Name { get; set; }
}
'DataGridView.AutoSize = true;'를 코드와 함께 설정해보십시오 (어떤 이유로 디자이너에 표시되지 않음). –
[DataGridView 자동 높이 - AutoGridView 높이 방법?] (http://stackoverflow.com/q/38816425/3110834) –