Artikel ini selangkah demi selangkah menjelaskan cara untuk menyortir
ListView kontrol oleh kolom dalam Visual C# aplikasi Anda.
Ketika Anda bekerja dengan
ListView kontrol, Anda mungkin ingin untuk menyortir isinya berdasarkan kolom tertentu. Contoh fungsi semacam ini terjadi dalam program Windows Explorer ketika Anda melihat isi folder di harddisk Anda. Dalam tampilan rincian, Windows Explorer menampilkan informasi tentang file dalam folder. Misalnya, Anda melihat nama file, ukuran file, jenis file dan tanggal yang diubah, berkas. Ketika Anda mengklik salah satu kolom header, daftar diurutkan dalam urutan yang didasarkan pada kolom. Ketika Anda klik header kolom yang sama lagi, kolom yang diurutkan dalam urutan.
Contoh dalam artikel ini mendefinisikan sebuah kelas yang mewarisi dari
IComparer antarmuka. Selain itu, contoh ini menggunakan
Membandingkan metode
CaseInsenstiveComparer kelas untuk melakukan perbandingan aktual item. Perhatikan bahwa metode ini perbandingan tidak peka ("Apple" dianggap sama "Apple"). Juga, perhatikan bahwa semua kolom dalam contoh ini diurutkan dalam cara yang "teks". Jika Anda ingin untuk menyortir dengan cara yang berbeda (seperti numerik), Anda dapat mengganti baris kode berikut dengan mana pendekatan untuk menyortir yang ingin Anda gunakan:
ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
Bagaimana membangun contoh proyek
- Membuat aplikasi proyek Visual C# Windows baru. Form1 dibuat secara default.
- Tambahkan ListView mengontrol Form1. Ukuran formulir untuk beberapa inci oleh beberapa inci tinggi.
- Paste kode berikut ke kelas untuk bentuk:
private ListViewColumnSorter lvwColumnSorter;
- Paste kode berikut ke konstruktor untuk bentuk, setelah panggilan untuk InitializeComponent metode:
// Create an instance of a ListView column sorter and assign it
// to the ListView control.
lvwColumnSorter = new ListViewColumnSorter();
this.listView1.ListViewItemSorter = lvwColumnSorter;
- Paste kode berikut ke Beban acara untuk formulir:
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;
}
Catatan Kode harus berubah dalam Visual Studio 2005. Bila Anda membuat proyek Windows Forms, Visual C# menambahkan salah satu bentuk proyek secara default. Formulir ini dinamakan Form1. Dua file yang mewakili bentuk yang bernama Form1.cs dan Form1.designer.cs. Anda menulis kode dalam Form1.cs. Designer.cs file adalah di mana Windows Forms Designer menulis kode sumber yang mengimplementasikan semua tindakan Anda dilakukan dengan menambahkan kontrol.
Untuk informasi lebih lanjut tentang Windows bentuk desainer Visual C# 2005, kunjungi Web site Microsoft berikut: - Paste kode berikut ke ColumnClick acara untuk ListView kontrol:
// 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();
- Pada Project menu, klik Menambahkan kelas menambahkan kelas baru untuk proyek.
- Mengganti semua kode standar dalam kelas baru dengan kode berikut:
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;
}
}
}
- Simpan, membangun, dan kemudian jalankan contoh proyek.
- Klik header kolom berbagai di ListView kontrol. Ketika Anda klik header, isi ListView kontrol diurutkan dalam urutan yang didasarkan pada kolom yang Anda klik. Ketika Anda klik header kolom yang sama lagi, kolom yang diurutkan dalam urutan.