Visual C# を使用して、列を使用して ListView コントロールを並べ替える
この記事では、Visual C# の列を使用して ListView コントロールを並べ替える方法について説明し、メソッドを説明するコード サンプルも提供します。
元の製品バージョン: Visual C#
元の KB 番号: 319401
概要
ListView コントロールを使用する場合は、特定の列に基づいて内容を並べ替えることができます。 この種の機能の例は、ハード ディスク上のフォルダーの内容を表示するときに、Windows エクスプローラー プログラムで発生します。 [詳細] ビューでは、Windows エクスプローラーはそのフォルダー内のファイルに関する情報を表示します。 たとえば、ファイル名、ファイル サイズ、ファイルの種類、ファイルが変更された日付が表示されます。 列ヘッダーの 1 つをクリックすると、その列に基づいてリストが昇順で並べ替えられます。 同じ列ヘッダーをもう一度クリックすると、列は降順で並べ替えられます。
この記事の例では、 インターフェイスから継承するクラスを IComparer
定義します。 さらに、この例では、 クラスの メソッドをCompare
CaseInsenstiveComparer
使用して、項目の実際の比較を実行します。
注:
- この比較方法では、大文字と小文字は区別されません。
- この例のすべての列は、 テキスト 形式で並べ替えられます。
別の方法 (数値など) で並べ替える場合は、次のコード行を使用する並べ替え方法に置き換えることができます。
ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
サンプル プロジェクトをビルドする手順
新しい Visual C# Windows アプリケーション プロジェクトを作成します。 Form1 は既定で作成されます。
ListView コントロールを Form1 に追加します。 フォームの幅を数インチ、高さ数インチに設定します。
フォームの クラスに次のコードを貼り付けます。
private ListViewColumnSorter lvwColumnSorter;
メソッドの呼び出しの後に、フォームのコンストラクターに次のコードを
InitializeComponent
貼り付けます。// Create an instance of a ListView column sorter and assign it // to the ListView control. lvwColumnSorter = new ListViewColumnSorter(); this.listView1.ListViewItemSorter = lvwColumnSorter;
フォームのイベントに次の
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#)」を参照してください。
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();
[ プロジェクト ] メニューの [ クラスの追加 ] をクリックして、新しいクラスをプロジェクトに追加します。
新しいクラスのすべての既定のコードを次のコードに置き換えます。
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; } } }
サンプル プロジェクトを保存、ビルド、実行します。
ListView コントロール内のさまざまな列ヘッダーをクリックします。 ヘッダーをクリックすると、ListView コントロールの内容は、クリックした列に基づいて昇順で並べ替えられます。 同じ列ヘッダーをもう一度クリックすると、その列は降順で並べ替えられます。