问题现象:
一:当ListView组件的列宽度总和小于ListView工作区宽度时出现一个空白列(见图一);
二:当ListView组件的列宽度总和大于ListView工作区宽度时出现横向滚动条(见图二);
图一
图二
问题原因:
ListView 出现空白列或者横向滚动条,是因为列宽度固定,而列宽度总和小于或者大于工作区宽度造成的。
解决方案:
要解决 ListView 出现空白列或者横向滚动条的问题,就需要某一列或者多列宽度自适应,列宽度总和始终等于工作区宽度就可以了。
public partial class FormMain : Form
{
public FormMain()
{
InitializeComponent();
}
private void FormMain_Load(object sender, EventArgs e)
{
string[] titles = {
"Lorem ipsum dolor sit amet, maecenas imperdiet, nullam lacus.",
"Egestas adipiscing est.",
"Nulla wisi varius, tincidunt etiam.",
"Sociis sit, ut imperdiet.",
"Cras curabitur vivamus.",
"Pretium wisi wisi, morbi tellus nulla.",
"Consectetuer quam, at in.",
"Fringilla vestibulum lacinia, morbi vitae sapien, eget porta.",
"Sed iaculis, accumsan tortor.",
"Amet mi, ullamcorper erat.",
"Tristique netus nunc, donec in quis, aptent aliquet pellentesque.",
"Nunc justo vitae, pellentesque felis duis, cursus mi purus.",
"Commodo pharetra cum, lorem sodales, augue a facilisis.",
"Aliquam facilisis mi, etiam penatibus blanditiis, mus vel morbi.",
"Nisl nulla, interdum nulla aenean.",
"Sapien ligula, dui lacinia, donec ante.",
"Aenean etiam libero.",
"Velit laudantium, penatibus pellentesque, sed quisque pulvinar.",
"Quis repellendus.",
"Enim augue volutpat, nec cubilia, non turpis."
};
ListViewMain.Columns.Add(new ColumnHeader() { Text = "ID", Width = 40 });
ListViewMain.Columns.Add(new ColumnHeader() { Text = "Title" });
for (int i = 0; i < 20; i++)
{
ListViewMain.Items.Add(new ListViewItem(new string[] { (i + 1).ToString().PadLeft(2, '0'), titles[i] }));
}
// 第一列宽度 + 第二列宽度 = 工作区宽度
ListViewMain.Columns[1].Width = ListViewMain.ClientSize.Width - ListViewMain.Columns[0].Width;
}
/// <summary>
/// 跟随窗体尺寸变化
/// </summary>
private void FormMain_SizeChanged(object sender, EventArgs e)
{
ListViewMain.Columns[1].Width = ListViewMain.ClientSize.Width - ListViewMain.Columns[0].Width;
}
}
最终效果:
图三
图四
WinForm ListView 列宽自适应技巧
本文介绍了WinForm ListView组件在列宽度设置上遇到的问题,包括列宽总和小于工作区宽度导致的空白列和列宽总和大于工作区宽度产生的横向滚动条。解决方案是实现列宽度自适应,确保列宽度总和始终等于工作区宽度,从而消除空白列和滚动条。最终展示了调整后的理想效果。





