Visual C# を使用して、列を使用して ListView コントロールを並べ替える

この記事では、Visual C# の列を使用して ListView コントロールを並べ替える方法について説明し、メソッドを説明するコード サンプルも提供します。

元の製品バージョン: Visual C#
元の KB 番号: 319401

概要

ListView コントロールを使用する場合は、特定の列に基づいて内容を並べ替えることができます。 この種の機能の例は、ハード ディスク上のフォルダーの内容を表示するときに、Windows エクスプローラー プログラムで発生します。 [詳細] ビューでは、Windows エクスプローラーはそのフォルダー内のファイルに関する情報を表示します。 たとえば、ファイル名、ファイル サイズ、ファイルの種類、ファイルが変更された日付が表示されます。 列ヘッダーの 1 つをクリックすると、その列に基づいてリストが昇順で並べ替えられます。 同じ列ヘッダーをもう一度クリックすると、列は降順で並べ替えられます。

この記事の例では、 インターフェイスから継承するクラスを IComparer 定義します。 さらに、この例では、 クラスの メソッドをCompareCaseInsenstiveComparer使用して、項目の実際の比較を実行します。

注:

  • この比較方法では、大文字と小文字は区別されません。
  • この例のすべての列は、 テキスト 形式で並べ替えられます。

別の方法 (数値など) で並べ替える場合は、次のコード行を使用する並べ替え方法に置き換えることができます。

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

サンプル プロジェクトをビルドする手順

  1. 新しい Visual C# Windows アプリケーション プロジェクトを作成します。 Form1 は既定で作成されます。

  2. ListView コントロールを Form1 に追加します。 フォームの幅を数インチ、高さ数インチに設定します。

  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 フォーム プロジェクトを作成すると、Visual C# は既定で 1 つのフォームをプロジェクトに追加します。 このフォームの名前は Form1 です。 フォームを表す 2 つのファイルには、 Form1.cs と Form1.designer.cs という名前が付 けられますForm1.csでコードを記述します。 Designer.cs ファイルは、コントロールを追加して実行したすべてのアクションを実装するコードをWindows フォーム Designerが書き込む場所です。 Visual C# のWindows フォーム 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 コントロールの内容は、クリックした列に基づいて昇順で並べ替えられます。 同じ列ヘッダーをもう一度クリックすると、その列は降順で並べ替えられます。