Makale numarası: 319401 - Son Gözden Geçirme: 13 Mart 2008 Perşembe - Gözden geçirme: 3.1

Bir liste görünümü denetimi, Visual C# içinde bir bir sütuna göre sıralama

Sistem İpucuBu makale, kullandığınızdan farklı bir işletim sistemine yöneliktir. Sizinle ilgili olmayabilecek makale içeriği devre dışı bırakıldı.

Bu Sayfada

Hepsini aç | Hepsini kapa

Özet

Bu adım adım makalede, bir liste görünümü denetimi, Visual C# uygulamasında bir sütunu sıralama açıklamaktadır.

ListView denetimiyle çalışırken, belirli bir sütunu temel alan içeriğini sıralamak isteyebilirsiniz. Sabit diskinizde bir klasörün içeriğini görüntülediğinizde, bu tür bir işlev örneği bir Windows Gezgini programında oluşur. Ayrıntılar görünümünde, Windows Gezgini, dosyaları bu klasöre hakkındaki bilgileri görüntüler. Örneğin, dosya adı, dosya boyutu, dosya türünü ve dosyanın değiştirilme tarihi bakın. Sütun başlıkları birini tıklattığınızda, listede bu sütunu göre artan düzende sıralanır. Aynı sütun başlığını yeniden tıklatın, sütun, azalan düzende sıralanır.

Bu makaledeki örnek IComparer arabirimden devralan bir sınıf tanımlar. Ayrıca, bu örnek, maddelerin fiili karşılaştırmasını yapmak için <a0>CaseInsenstiveComparer</a0> sınıfının <a2>Karşılaştırılacak</a2> yöntemini kullanır. Bu yöntem, karşılaştırma, büyük/küçük harf duyarlı olduğunu unutmayın ("Apple" "elma" aynı kabul edilir). Ayrıca, bu örnekte sütunların tümünü bir "metin" şekilde sıralanacağını unutmayın. Farklı bir şekilde sıralamak istiyorsanız (gibi sayısal), aşağıdaki kod satırını, sıralamayı hangi yaklaşımı kullanmak istediğiniz ile değiştirebilir:
ObjectCompare.Compare(listviewX.SubItems[ColumnToSort].Text,listviewY.SubItems[ColumnToSort].Text);
				

Nasıl yapılır: örnek Projeyi derleyin

  1. Yeni bir Visual C# Windows uygulaması projesi oluşturun. Varsayılan olarak, Form1 oluşturulur.
  2. Bir liste görünümü denetimi Form1'e ekleyin. Formun birkaç inç olarak birkaç inç boyunda olarak boyutu.
  3. Sınıf form için aşağıdaki kodu yapıştırın:
    private ListViewColumnSorter lvwColumnSorter;
    					
  4. Aşağıdaki kodu formun kurucu ınitializecomponent yöntemini çağrısının yapıştırın:
    // Create an instance of a ListView column sorter and assign it 
    // to the ListView control.
    lvwColumnSorter = new ListViewColumnSorter();
    this.listView1.ListViewItemSorter = lvwColumnSorter;
    					
  5. Formun Load olayı aşağıdaki kodu yapıştırın:
    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;
    }
    					
    Not kodunu Visual Studio 2005'te değiştirilmelidir. Windows Forms bir proje oluşturduğunuzda, Visual C# bir form projeye varsayılan olarak ekler. Bu formu Form1 ' dir. Form temsil eden iki dosya Form1.cs ve Form1.designer.cs olarak adlandırılır. Kodunuzu, Form1.cs içinde yazın. Burada Windows Form Designer denetimleri ekleyerek gerçekleştirilen tüm eylemleri gerçekleştiren kod yazma Designer.cs dosyasıdır. Visual C# 2005'te Windows Forms Tasarımcısı hakkında daha fazla bilgi için aşağıdaki Microsoft Web sitesini ziyaret edin:
    http://msdn2.microsoft.com/en-us/library/ms173077.aspx (http://msdn2.microsoft.com/en-us/library/ms173077.aspx)
  6. ListView denetim ColumnClick olay aşağıdaki kodu yapıştırın:
    // 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. Proje menüsünde Proje için yeni sınıf eklemek için Add Class ' ı tıklatın.
  8. Tüm yeni bir sınıf içinde <a2>Varsayılan</a2> kodu aşağıdaki kodla değiştirin:
    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. Kaydet, oluşturmak ve örnek projeyi çalıştırın.
  10. ListView denetiminde çeşitli sütun başlıkları Ek Yardım düğmesini tıklatın. Üstbilgiyi tıklattığınızda ListView denetimin içeriğini tıklattığınız sütuna göre artan düzende sıralanır. Aynı sütun başlığını yeniden tıklatın, sütun, azalan düzende sıralanır.

Bu makaledeki bilginin uygulandığı durum:
  • Microsoft Visual C# .NET 2002 Standard Edition
  • Microsoft Visual C# 2005 Express Edition
  • Microsoft Visual C# 2008 Express Edition
Anahtar Kelimeler: 
kbmt kbctrl kbhowtomaster kblistview KB319401 KbMttr
Otomatik TercümeOtomatik Tercüme
ÖNEMLİ: Bu makale, bir kişi tarafından çevrilmek yerine, Microsoft makine-çevirisi yazılımı ile çevrilmiştir. Microsoft size hem kişiler tarafından çevrilmiş, hem de makine-çevrisi ile çevrilmiş makaleler sunar. Böylelikle, bilgi bankamızdaki tüm makalelere, kendi dilinizde ulaşmış olursunuz. Bununla birlikte, makine tarafından çevrilmiş makaleler mükemmel değildir. Bir yabancının sizin dilinizde konuşurken yapabileceği hatalar gibi, makale; kelime dağarcığı, söz dizim kuralları veya dil bilgisi açısından yanlışlar içerebilir. Microsoft, içeriğin yanlış çevrimi veya onun müşteri tarafından kullanımından doğan; kusur, hata veya zarardan sorumlu değildir. Microsoft ayrıca makine çevirisi yazılımını sıkça güncellemektedir.
Makalenin İngilizcesi aşağıdaki gibidir:319401  (http://support.microsoft.com/kb/319401/en-us/ )