Visual C#을 사용하여 열을 사용하여 ListView 컨트롤 정렬

이 문서에서는 Visual C#의 열을 사용하여 ListView 컨트롤을 정렬하는 방법에 대한 정보를 제공하고 메서드를 설명하는 코드 샘플도 제공합니다.

원래 제품 버전: Visual C#
원래 KB 번호: 319401

요약

ListView 컨트롤을 사용하는 경우 특정 열에 따라 콘텐츠를 정렬할 수 있습니다. 이러한 종류의 기능의 예는 하드 디스크에서 폴더의 내용을 볼 때 Windows Explorer 프로그램에서 발생합니다. 세부 정보 보기에서 Windows Explorer 해당 폴더의 파일에 대한 정보를 표시합니다. 예를 들어 파일 이름, 파일 크기, 파일 형식 및 파일이 수정된 날짜가 표시됩니다. 열 머리글 중 하나를 클릭하면 목록이 해당 열에 따라 오름차순으로 정렬됩니다. 동일한 열 머리글을 다시 클릭하면 열이 내림차순으로 정렬됩니다.

이 문서의 예제에서는 인터페이스에서 상속되는 클래스를 IComparer 정의합니다. 또한 이 예제에서는 클래스의 메서드를 CaseInsenstiveComparer 사용하여 Compare 항목의 실제 비교를 수행합니다.

참고

  • 이 비교 방법은 대/소문자를 구분하지 않습니다.
  • 이 예제의 모든 열은 텍스트 방식으로 정렬됩니다.

다른 방식으로 정렬하려는 경우(예: 숫자) 다음 코드 줄을 사용하려는 정렬 방법 중 하나로 바꿀 수 있습니다.

ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);

샘플 프로젝트를 빌드하는 단계

  1. 새 Visual C# Windows 애플리케이션 프로젝트를 만듭니다. Form1 은 기본적으로 만들어집니다.

  2. Form1에 ListView 컨트롤을 추가합니다. 폼의 너비를 몇 인치 높이로 조정합니다.

  3. 양식의 클래스에 다음 코드를 붙여넣습니다.

    private ListViewColumnSorter lvwColumnSorter;
    
  4. 메서드를 호출 InitializeComponent 한 후 폼의 생성자에 다음 코드를 붙여넣습니다.

    // Create an instance of a ListView column sorter and assign it
    // to the ListView control.
    lvwColumnSorter = new ListViewColumnSorter();
    this.listView1.ListViewItemSorter = lvwColumnSorter;
    
  5. 양식의 이벤트에 다음 코드를 붙여넣 Load 습니다.

    ColumnHeader columnheader;// Used for creating column headers.
    ListViewItem listviewitem;// Used for creating listview items.
    
    // Ensure that the view is set to show details.
    listView1.View = View.Details;
    
    // Create some listview items consisting of first and last names.
    listviewitem = new ListViewItem("John");
    listviewitem.SubItems.Add("Smith");
    this.listView1.Items.Add(listviewitem);
    
    listviewitem = new ListViewItem("Bob");
    listviewitem.SubItems.Add("Taylor");
    this.listView1.Items.Add(listviewitem);
    
    listviewitem = new ListViewItem("Kim");
    listviewitem.SubItems.Add("Zimmerman");
    this.listView1.Items.Add(listviewitem);
    
    listviewitem = new ListViewItem("Olivia");
    listviewitem.SubItems.Add("Johnson");
    this.listView1.Items.Add(listviewitem);
    
    // Create some column headers for the data.
    columnheader = new ColumnHeader();
    columnheader.Text = "First Name";
    this.listView1.Columns.Add(columnheader);
    
    columnheader = new ColumnHeader();
    columnheader.Text = "Last Name";
    this.listView1.Columns.Add(columnheader);
    
    // Loop through and size each column header to fit the column header text.
    foreach (ColumnHeader ch in this.listView1.Columns)
    {
        ch.Width = -2;
    }
    

    참고

    Visual Studio에서 코드를 변경해야 합니다. Windows Forms 프로젝트를 만들 때 Visual C#은 기본적으로 프로젝트에 하나의 양식을 추가합니다. 이 양식의 이름은 Form1입니다. 폼을 나타내는 두 파일의 이름은 Form1.csForm1.designer.cs. Form1.cs 코드를 작성합니다. Designer.cs 파일은 Windows Forms Designer 컨트롤을 추가하여 수행한 모든 작업을 구현하는 코드를 작성하는 위치입니다. Visual C#의 Windows Forms Designer 대한 자세한 내용은 프로젝트 만들기(Visual C#)를 참조하세요.

  6. ListView 컨트롤의 ColumnClick 이벤트에 다음 코드를 붙여넣습니다.

    // Determine if clicked column is already the column that is being sorted.
    if (e.Column == lvwColumnSorter.SortColumn)
    {
        // Reverse the current sort direction for this column.
        if (lvwColumnSorter.Order == SortOrder.Ascending)
        {
            lvwColumnSorter.Order = SortOrder.Descending;
        }
        else
        {
            lvwColumnSorter.Order = SortOrder.Ascending;
        }
    }
    else
    {
        // Set the column number that is to be sorted; default to ascending.
        lvwColumnSorter.SortColumn = e.Column;
        lvwColumnSorter.Order = SortOrder.Ascending;
    }
    
    // Perform the sort with these new sort options.
    this.listView1.Sort();
    
  7. 프로젝트 메뉴에서 클래스 추가를 클릭하여 프로젝트에 새 클래스를 추가합니다.

  8. 새 클래스의 모든 기본 코드를 다음 코드로 바꿉 있습니다.

    using System.Collections;
    using System.Windows.Forms;
    
    /// <summary>
    /// This class is an implementation of the 'IComparer' interface.
    /// </summary>
    public class ListViewColumnSorter : IComparer
    {
        /// <summary>
        /// Specifies the column to be sorted
        /// </summary>
        private int ColumnToSort;
    
        /// <summary>
        /// Specifies the order in which to sort (i.e. 'Ascending').
        /// </summary>
        private SortOrder OrderOfSort;
    
        /// <summary>
        /// Case insensitive comparer object
        /// </summary>
        private CaseInsensitiveComparer ObjectCompare;
    
        /// <summary>
        /// Class constructor. Initializes various elements
        /// </summary>
        public ListViewColumnSorter()
        {
            // Initialize the column to '0'
            ColumnToSort = 0;
    
            // Initialize the sort order to 'none'
            OrderOfSort = SortOrder.None;
    
            // Initialize the CaseInsensitiveComparer object
            ObjectCompare = new CaseInsensitiveComparer();
        }
    
        /// <summary>
        /// This method is inherited from the IComparer interface. It compares the two objects passed using a case insensitive comparison.
        /// </summary>
        /// <param name="x">First object to be compared</param>
        /// <param name="y">Second object to be compared</param>
        /// <returns>The result of the comparison. "0" if equal, negative if 'x' is less than 'y' and positive if 'x' is greater than 'y'</returns>
        public int Compare(object x, object y)
        {
            int compareResult;
            ListViewItem listviewX, listviewY;
    
            // Cast the objects to be compared to ListViewItem objects
            listviewX = (ListViewItem)x;
            listviewY = (ListViewItem)y;
    
            // Compare the two items
            compareResult = ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
    
            // Calculate correct return value based on object comparison
            if (OrderOfSort == SortOrder.Ascending)
            {
                // Ascending sort is selected, return normal result of compare operation
                return compareResult;
            }
            else if (OrderOfSort == SortOrder.Descending)
            {
                // Descending sort is selected, return negative result of compare operation
                return (-compareResult);
            }
            else
            {
                // Return '0' to indicate they are equal
                return 0;
            }
        }
    
        /// <summary>
        /// Gets or sets the number of the column to which to apply the sorting operation (Defaults to '0').
        /// </summary>
        public int SortColumn
        {
            set
            {
                ColumnToSort = value;
            }
            get
            {
                return ColumnToSort;
            }
        }
    
        /// <summary>
        /// Gets or sets the order of sorting to apply (for example, 'Ascending' or 'Descending').
        /// </summary>
        public SortOrder Order
        {
            set
            {
                OrderOfSort = value;
            }
            get
            {
                return OrderOfSort;
            }
        }
    
    }
    
  9. 샘플 프로젝트를 저장, 빌드 및 실행합니다.

  10. ListView 컨트롤에서 다양한 열 머리글을 클릭합니다. 머리글을 클릭하면 ListView 컨트롤의 내용이 클릭한 열에 따라 오름차순으로 정렬됩니다. 동일한 열 머리글을 다시 클릭하면 해당 열이 내림차순으로 정렬됩니다.