DataGridView 自动调整和填充
Posted
技术标签:
【中文标题】DataGridView 自动调整和填充【英文标题】:DataGridView AutoFit and Fill 【发布时间】:2013-09-11 01:46:16 【问题描述】:我的DataGridView
中有 3 列。我想要做的是让前 2 列自动适应内容的宽度,并让第 3 列填充剩余空间。
是否可以在 WinForms 中进行?如果有任何用处,我将从 EF DataContext 加载我的数据。我已经附上了它当前外观的图片。
【问题讨论】:
【参考方案1】:您需要使用DataGridViewColumn.AutoSizeMode
属性。
您可以对第 0 列和第 1 列使用以下值之一:
AllCells: 调整列宽以适合所有单元格的内容 列,包括标题单元格。 AllCellsExceptHeader: 调整列宽以适应列中所有单元格的内容,不包括标题单元格。 DisplayedCells: 列宽调整为 适合当前在行中的列中所有单元格的内容 显示在屏幕上,包括标题单元格。 DisplayedCellsExceptHeader: 调整列宽以适应 当前在行中的列中所有单元格的内容 显示在屏幕上,不包括标题单元格。
然后你对第 2 列使用 Fill 值
调整列宽,使所有列的宽度完全填满控件的显示区域...
this.DataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
this.DataGridView1.Columns[1].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
this.DataGridView1.Columns[2].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
正如其他用户所指出的,可以使用DataGridView.AutoSizeColumnsMode
属性将默认值设置为datagridview
级别。
this.DataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
this.DataGridView1.Columns[1].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
可能是:
this.DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.DisplayedCells;
重要提示:
如果您的网格绑定到数据源并且列是自动生成的(AutoGenerateColumns
属性设置为 True),您需要使用 DataBindingComplete
事件来应用样式AFTER列创建的。
在某些情况下(例如通过代码更改单元格值),我必须调用 DataGridView1.AutoResizeColumns();
来刷新网格。
【讨论】:
在使用 DataBindingComplete 事件时完美运行。 我不知道如何在填充数据网格后调用 DataBindingComplete 方法 @Dan DataBindingComplete 不是一个方法,它是一个你需要订阅的datagridview event。这个答案***.com/a/31685874/2387010 给出了一个例子。有帮助吗? 如果解释了这个例子会很有帮助,但也足够了。 MSDN article that you linked to in your post 将其显示为一种方法,这是我用作我的模式但无法弄清楚它是如何被调用的。 @Chris 丢失的信息绝对有帮助,谢谢。我正在阅读this book 并且刚刚 读到了关于委托和 lambda 函数的章节,所以希望这会很快变得更有意义。谢谢!【参考方案2】:这是我最喜欢的方法...
_dataGrid.DataBindingComplete += (o, _) =>
var dataGridView = o as DataGridView;
if (dataGridView != null)
dataGridView.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
dataGridView.Columns[dataGridView.ColumnCount-1].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
;
【讨论】:
如果列大小 =0,index out of bound exception
只需修复它,谢谢!!【参考方案3】:
只需从控制属性更改属性:
AutoSizeColumnsMode:Fill
或按代码
dataGridView1.AutoSizeColumnsMode=DataGridViewAutoSizeColumnsMode.Fill;
【讨论】:
谢谢。我一直在寻找这样的解决方案! :)【参考方案4】:未测试,但您可以试一试。 已测试且工作正常。我希望你可以和AutoSizeMode
的DataGridViewColum
一起玩来实现你所需要的。
尝试设置
dataGridView1.DataSource = yourdatasource;<--set datasource before you set AutoSizeMode
//Set the following properties after setting datasource
dataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
dataGridView1.Columns[1].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
dataGridView1.Columns[2].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
这应该可以工作
【讨论】:
这不起作用。我在从 DataContext 添加数据源之前初始化表单时设置它。这可能是为什么?我不确定在哪里设置它,因为数据是在运行时加载的,并且列是从 EF 模型中获取的。 貌似是这样,但不是,第三行不行,我10分钟前测试过。 @JamesJeffery 你是自动填充列还是手动填充? @SriramSakthivel 我正在使用 dataGridView1.DataSource 属性绑定从我的 DataContext 返回的列表。【参考方案5】:尝试做,
AutoSizeColumnMode = Fill;
【讨论】:
【参考方案6】:public static void Fill(DataGridView dgv2)
try
dgv = dgv2;
foreach (DataGridViewColumn GridCol in dgv.Columns)
for (int j = 0; j < GridCol.DataGridView.ColumnCount; j++)
GridCol.DataGridView.Columns[j].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
GridCol.DataGridView.Columns[j].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
GridCol.DataGridView.Columns[j].FillWeight = 1;
catch (Exception ex)
MessageBox.Show(ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
【讨论】:
这段代码不是很好。首先,您不需要嵌套循环,它将所有列的宽度模式设置为多次()次;您可以直接从GridCol
访问每列的 AutoSizeMode 和 FillWeight 属性。其次,它将每列的 AutoSizeMode 设置为两个不同的值;第二个分配将覆盖第一个。【参考方案7】:
以 AlfredBr 的回答为基础,如果您隐藏了一些列,您可以使用以下方法自动调整所有列的大小,然后让最后一个可见列填充空白区域:
myDgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
myDgv.Columns.GetLastColumn(DataGridViewElementStates.Visible, DataGridViewElementStates.None).AutoSizeMode =
DataGridViewAutoSizeColumnMode.Fill;
【讨论】:
【参考方案8】:这是我所做的,以便在所有列都无法做到这一点时让“first_name”列填充空间。
当网格变小时,“first_name”列几乎不可见(非常薄),因此我可以将DataGridViewAutoSizeColumnMode
属性设置为AllCells
,作为其他可见列。对于性能问题,重要的是在数据绑定之前将它们设置为None
,并在网格的DataBindingComplete
事件处理程序中设置回AllCells
。希望对您有所帮助!
private void dataGridView1_Resize(object sender, EventArgs e)
int ColumnsWidth = 0;
foreach(DataGridViewColumn col in dataGridView1.Columns)
if (col.Visible) ColumnsWidth += col.Width;
if (ColumnsWidth <dataGridView1.Width)
dataGridView1.Columns["first_name"].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
else if (dataGridView1.Columns["first_name"].Width < 10)
dataGridView1.Columns["first_name"].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
【讨论】:
【参考方案9】:public void setHeight(DataGridView src)
src.Height= src.ColumnHeadersVisible ? src.ColumnHeadersHeight : 0 + src.Rows.OfType<DataGridViewRow>().Where(row => row.Visible).Sum(row => row.Height);
【讨论】:
只需调用该函数,它会根据其中的行数来决定datagridview的高度 首先,这并没有回答 OP 的问题。此外(供将来参考)包括对答案本身的此类评论(您可以对其进行编辑)。【参考方案10】:试试这个:
DGV.AutoResizeColumns();
DGV.AutoSizeColumnsMode=DataGridViewAutoSizeColumnsMode.AllCells;
【讨论】:
以上是关于DataGridView 自动调整和填充的主要内容,如果未能解决你的问题,请参考以下文章
C#的dataGridView控件里面已经有数据了,怎么让它自动统计总行数?[自动统计:没有点击等任何事件时]
如何自动调整 DataGridView 控件中的列大小并允许用户调整同一网格上的列大小?