C#ListView列宽自动

问题描述 投票:69回答:10

如何将c#winforms listview控件的列宽设置为auto。宽度= -1 / -2之类的东西?

c# .net winforms listview width
10个回答
99
投票

您给出了答案:-2将列自动调整为列标题中文本的长度,-1将自动调整为列中最长的项目。 All according to MSDN。请注意,在-1的情况下,您需要在添加项目后设置列宽。因此,如果添加新项,则还需要根据ListView控件中的数据指定要自动调整大小的列(或列)的width属性。


-1
投票

我相信作者正在寻找一个通过IDE的等效方法,它将生成后面的代码,并确保所有参数都已到位,等等。从MS发现:

Creating Event Handlers on the Windows Forms Designer

来自VB背景我自己,这就是我想要的,这里是点击不利的简要版本:

  1. 单击要为其创建事件处理程序的表单或控件。
  2. 在“属性”窗口中,单击“事件”按钮
  3. 在可用事件列表中,单击要为其创建事件处理程序的事件。
  4. 在事件名称右侧的框中,键入处理程序的名称,然后按Enter

87
投票

用这个:

yourListView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent);
yourListView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.HeaderSize);

来自here


22
投票

我做了一个程序,多次清理并重新填充我的列表视图。出于某种原因,每当我添加width = -2的列时,我遇到第一列太长的问题。我为解决这个问题所做的就是创建这个方法。

private void ResizeListViewColumns(ListView lv)
{
    foreach(ColumnHeader column in lv.Columns)
    {
        column.Width = -2;
    }
}

关于这种方法的好处是你几乎可以把它放在任何地方调整所有列的大小。只需通过你的ListView


1
投票

如果你想动态设置列的自动调整大小宽度,例如:将第一列的自动大小宽度设置为70,请扩展Fredrik的答案:

myListView.Columns[0].AutoResize(ColumnHeaderAutoResizeStyle.None);
myListView.Columns[0].Width = 70;
myListView.Columns[0].AutoResize(ColumnHeaderAutoResizeStyle.ColumnContent);

1
投票

此解决方案将首先根据列数据调整列的大小,如果调整大小的宽度小于标题大小,它将调整列的大小以至少适合标题。这是一个非常难看的解决方案,但它确实有效。

lstContacts.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent);
colFirstName.Width = (colFirstName.Width < 60 ? 60 : colFirstName.Width);
colLastName.Width = (colLastName.Width < 61 ? 61 : colLastName.Width);
colPhoneNumber.Width = (colPhoneNumber.Width < 81 ? 81 : colPhoneNumber.Width);
colEmail.Width = (colEmail.Width < 40 ? 40 : colEmail.Width);

lstContacts是ListView。 colFirstName是一列,其中60是适合标题所需的宽度。等等。


1
投票

如果您在任何父面板(ListView停靠点填充)中有ListView,则可以使用简单的方法...

private void ListViewHeaderWidth() {
        int HeaderWidth = (listViewInfo.Parent.Width - 2) / listViewInfo.Columns.Count;
        foreach (ColumnHeader header in listViewInfo.Columns)
        {
            header.Width = HeaderWidth;
        }
    }

0
投票

你可以使用这样的东西,在param中传递你想要的ListView

    private void AutoSizeColumnList(ListView listView)
    {
        //Prevents flickering
        listView.BeginUpdate();

        Dictionary<int, int> columnSize = new Dictionary<int,int>();

        //Auto size using header
        listView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.HeaderSize);

        //Grab column size based on header
        foreach(ColumnHeader colHeader in listView.Columns )
            columnSize.Add(colHeader.Index, colHeader.Width);

        //Auto size using data
        listView.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent);

        //Grab comumn size based on data and set max width
        foreach (ColumnHeader colHeader in listView.Columns)
        {
            int nColWidth;
            if (columnSize.TryGetValue(colHeader.Index, out nColWidth))
                colHeader.Width = Math.Max(nColWidth, colHeader.Width);
            else
                //Default to 50
                colHeader.Width = Math.Max(50, colHeader.Width);
        }

        listView.EndUpdate();
    }

0
投票

还有一种名为AutoResizeColumn的有用方法,允许您使用所需参数自动调整特定列的大小。

像这样:

listview1.AutoResizeColumn(1, ColumnHeaderAutoResizeStyle.ColumnContent);
listview1.AutoResizeColumn(2, ColumnHeaderAutoResizeStyle.ColumnContent);
listview1.AutoResizeColumn(3, ColumnHeaderAutoResizeStyle.HeaderSize);
listview1.AutoResizeColumn(4, ColumnHeaderAutoResizeStyle.HeaderSize);

0
投票

值得注意的是,如果没有先更改属性,ListView可能无法按预期显示:

myListView.View = View.Details; // or View.List

对我来说,Visual Studio似乎由于某种原因将其默认为View.LargeIcon,因此在更改之前不会显示任何内容。

完整代码以在ListView中显示单个列,并为垂直滚动条提供空间。

lisSerials.Items.Clear();
lisSerials.View = View.Details;
lisSerials.FullRowSelect = true;

// add column if not already present
if(lisSerials.Columns.Count==0)
{
    int vw = SystemInformation.VerticalScrollBarWidth;
    lisSerials.Columns.Add("Serial Numbers", lisSerials.Width-vw-5);
}

foreach (string s in stringArray)
{
    ListViewItem lvi = new ListViewItem(new string[] { s });
    lisSerials.Items.Add(lvi);
}
© www.soinside.com 2019 - 2024. All rights reserved.