Uwaga
Dostęp do tej strony wymaga autoryzacji. Może spróbować zalogować się lub zmienić katalogi.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Ten artykuł zawiera informacje o sposobie sortowania kontrolki ListView przy użyciu kolumny w języku Visual C#, a także zawiera przykładowy kod wyjaśniający metody.
Oryginalna wersja produktu: Visual C#
Oryginalny numer KB: 319401
Podsumowanie
Podczas pracy z kontrolką ListView możesz posortować jego zawartość na podstawie określonej kolumny. Przykład tego rodzaju funkcji występuje w programie Eksplorator Windows podczas wyświetlania zawartości folderu na dysku twardym. W widoku Szczegóły Eksplorator Windows wyświetla informacje o plikach w tym folderze. Na przykład zobaczysz nazwę pliku, rozmiar pliku, typ pliku i datę modyfikacji pliku. Po kliknięciu jednego z nagłówków kolumn lista jest sortowana w kolejności rosnącej na podstawie tej kolumny. Po ponownym kliknięciu tego samego nagłówka kolumny kolumna jest sortowana w kolejności malejącej.
W przykładzie w tym artykule zdefiniowano klasę dziedziczą z interfejsu IComparer
. Ponadto w tym przykładzie użyto Compare
metody CaseInsenstiveComparer
klasy do wykonania rzeczywistego porównania elementów.
Uwaga 16.
- Ta metoda porównania nie uwzględnia wielkości liter.
- Wszystkie kolumny w tym przykładzie są sortowane w sposób tekstowy.
Jeśli chcesz sortować w inny sposób (na przykład liczbowo), możesz zastąpić następujący wiersz kodu dowolną metodą sortowania, którego chcesz użyć:
ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
Kroki tworzenia przykładowego projektu
Utwórz nowy projekt aplikacji dla systemu Windows w języku Visual C#. Formularz1 jest tworzony domyślnie.
Dodaj kontrolkę ListView do formularza Form1. Rozmiar formularza, aby mieć kilka cali szerokości o kilka cali wysokości.
Wklej następujący kod do klasy formularza:
private ListViewColumnSorter lvwColumnSorter;
Wklej następujący kod do konstruktora formularza po wywołaniu
InitializeComponent
metody :// Create an instance of a ListView column sorter and assign it // to the ListView control. lvwColumnSorter = new ListViewColumnSorter(); this.listView1.ListViewItemSorter = lvwColumnSorter;
Wklej następujący kod do
Load
zdarzenia formularza: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; }
Uwaga 16.
Kod powinien zostać zmieniony w programie Visual Studio. Podczas tworzenia projektu Windows Forms program Visual C# domyślnie dodaje jeden formularz do projektu. Ten formularz nosi nazwę Form1. Dwa pliki reprezentujące formularz mają nazwę Form1.cs i Form1.designer.cs. Napiszesz kod w Form1.cs. Plik Designer.cs to miejsce, w którym program Windows Forms Designer zapisuje kod, który implementuje wszystkie akcje wykonywane przez dodanie kontrolek. Aby uzyskać więcej informacji na temat projektanta formularzy systemu Windows w visual C#, odwiedź stronę Tworzenie projektu (Visual C#).
Wklej następujący kod do
ColumnClick
zdarzenia dla kontrolki ListView:// 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();
W menu Project (Projekt) kliknij pozycję Add Class (Dodaj klasę), aby dodać nową klasę do projektu.
Zastąp cały kod domyślny w nowej klasie następującym kodem:
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; } } }
Zapisz, skompiluj, a następnie uruchom przykładowy projekt.
Kliknij różne nagłówki kolumn w kontrolce ListView. Po kliknięciu nagłówka zawartość kontrolki ListView jest sortowana w kolejności rosnącej na podstawie klikniętej kolumny. Po ponownym kliknięciu tego samego nagłówka kolumny ta kolumna jest sortowana w kolejności malejącej.