ListView.ColumnHeaderCollection Kelas
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
Mewakili kumpulan header kolom dalam ListView kontrol.
public: ref class ListView::ColumnHeaderCollection : System::Collections::IList
public class ListView.ColumnHeaderCollection : System.Collections.IList
[System.ComponentModel.ListBindable(false)]
public class ListView.ColumnHeaderCollection : System.Collections.IList
type ListView.ColumnHeaderCollection = class
interface IList
interface ICollection
interface IEnumerable
[<System.ComponentModel.ListBindable(false)>]
type ListView.ColumnHeaderCollection = class
interface IList
interface ICollection
interface IEnumerable
Public Class ListView.ColumnHeaderCollection
Implements IList
- Warisan
-
ListView.ColumnHeaderCollection
- Atribut
- Penerapan
Contoh
Contoh kode berikut membuat formulir yang berisi ListView kontrol yang secara manual mengurutkan item saat kolom dalam kontrol diklik ListView . Contoh mendefinisikan kelas yang disebut ListViewItemComparer
yang mengimplementasikan System.Collections.IComparer antarmuka yang melakukan perbandingan ListViewItem . Contoh membuat instans ListViewItemComparer
dan menggunakannya untuk mengatur ListViewItemSorter properti ListView kontrol. Panggilan Sort metode dalam penanganan ColumnClick aktivitas menggunakan metode yang ditentukan ListViewItemComparer
untuk melakukan jenis item, berdasarkan kolom yang diklik.
#using <System.dll>
#using <System.Drawing.dll>
#using <System.Windows.Forms.dll>
using namespace System;
using namespace System::Windows::Forms;
using namespace System::Drawing;
using namespace System::Collections;
// Implements the manual sorting of items by columns.
ref class ListViewItemComparer: public IComparer
{
private:
int col;
public:
ListViewItemComparer()
{
col = 0;
}
ListViewItemComparer( int column )
{
col = column;
}
virtual int Compare( Object^ x, Object^ y )
{
return String::Compare( (dynamic_cast<ListViewItem^>(x))->SubItems[ col ]->Text,
(dynamic_cast<ListViewItem^>(y))->SubItems[ col ]->Text );
}
};
public ref class ListViewSortForm: public Form
{
private:
ListView^ listView1;
public:
ListViewSortForm()
{
// Create ListView items to add to the control.
array<String^>^temp0 = {"Banana","a","b","c"};
ListViewItem^ listViewItem1 = gcnew ListViewItem( temp0,-1,Color::Empty,Color::Yellow,nullptr );
array<String^>^temp1 = {"Cherry","v","g","t"};
ListViewItem^ listViewItem2 = gcnew ListViewItem( temp1,-1,Color::Empty,Color::Red,
gcnew System::Drawing::Font( "Microsoft Sans Serif",8.25F,FontStyle::Regular,GraphicsUnit::Point,0 ) );
array<String^>^temp2 = {"Apple","h","j","n"};
ListViewItem^ listViewItem3 = gcnew ListViewItem( temp2,-1,Color::Empty,Color::Lime,nullptr );
array<String^>^temp3 = {"Pear","y","u","i"};
ListViewItem^ listViewItem4 = gcnew ListViewItem( temp3,-1,Color::Empty,Color::FromArgb( 192, 128, 156 ),nullptr );
//Initialize the ListView control and add columns to it.
this->listView1 = gcnew ListView;
// Set the initial sorting type for the ListView.
this->listView1->Sorting = SortOrder::None;
// Disable automatic sorting to enable manual sorting.
this->listView1->View = View::Details;
// Add columns and set their text.
this->listView1->Columns->Add( gcnew ColumnHeader );
this->listView1->Columns[ 0 ]->Text = "Column 1";
this->listView1->Columns[ 0 ]->Width = 100;
listView1->Columns->Add( gcnew ColumnHeader );
listView1->Columns[ 1 ]->Text = "Column 2";
listView1->Columns->Add( gcnew ColumnHeader );
listView1->Columns[ 2 ]->Text = "Column 3";
listView1->Columns->Add( gcnew ColumnHeader );
listView1->Columns[ 3 ]->Text = "Column 4";
// Suspend control logic until form is done configuring form.
this->SuspendLayout();
// Add Items to the ListView control.
array<ListViewItem^>^temp4 = {listViewItem1,listViewItem2,listViewItem3,listViewItem4};
this->listView1->Items->AddRange( temp4 );
// Set the location and size of the ListView control.
this->listView1->Location = Point(10,10);
this->listView1->Name = "listView1";
this->listView1->Size = System::Drawing::Size( 300, 100 );
this->listView1->TabIndex = 0;
// Enable editing of the items in the ListView.
this->listView1->LabelEdit = true;
// Connect the ListView::ColumnClick event to the ColumnClick event handler.
this->listView1->ColumnClick += gcnew ColumnClickEventHandler( this, &ListViewSortForm::ColumnClick );
// Initialize the form.
this->ClientSize = System::Drawing::Size( 400, 400 );
array<Control^>^temp5 = {this->listView1};
this->Controls->AddRange( temp5 );
this->Name = "ListViewSortForm";
this->Text = "Sorted ListView Control";
// Resume lay[Out] of* the form.
this->ResumeLayout( false );
}
private:
// ColumnClick event handler.
void ColumnClick( Object^ /*o*/, ColumnClickEventArgs^ e )
{
// Set the ListViewItemSorter property to a new ListViewItemComparer
// object. Setting this property immediately sorts the
// ListView using the ListViewItemComparer object.
this->listView1->ListViewItemSorter = gcnew ListViewItemComparer( e->Column );
}
};
[System::STAThreadAttribute]
int main()
{
Application::Run( gcnew ListViewSortForm );
}
using System;
using System.Windows.Forms;
using System.Drawing;
using System.Collections;
namespace ListViewSortFormNamespace
{
public class ListViewSortForm : Form
{
private ListView listView1;
public ListViewSortForm()
{
// Create ListView items to add to the control.
ListViewItem listViewItem1 = new ListViewItem(new string[] {"Banana","a","b","c"}, -1, Color.Empty, Color.Yellow, null);
ListViewItem listViewItem2 = new ListViewItem(new string[] {"Cherry","v","g","t"}, -1, Color.Empty, Color.Red, new Font("Microsoft Sans Serif", 8.25F, FontStyle.Regular, GraphicsUnit.Point, ((System.Byte)(0))));
ListViewItem listViewItem3 = new ListViewItem(new string[] {"Apple","h","j","n"}, -1, Color.Empty, Color.Lime, null);
ListViewItem listViewItem4 = new ListViewItem(new string[] {"Pear","y","u","i"}, -1, Color.Empty, Color.FromArgb(((System.Byte)(192)), ((System.Byte)(128)), ((System.Byte)(156))), null);
//Initialize the ListView control and add columns to it.
this.listView1 = new ListView();
// Set the initial sorting type for the ListView.
this.listView1.Sorting = SortOrder.None;
// Disable automatic sorting to enable manual sorting.
this.listView1.View = View.Details;
// Add columns and set their text.
this.listView1.Columns.Add(new ColumnHeader());
this.listView1.Columns[0].Text = "Column 1";
this.listView1.Columns[0].Width = 100;
listView1.Columns.Add(new ColumnHeader());
listView1.Columns[1].Text = "Column 2";
listView1.Columns.Add(new ColumnHeader());
listView1.Columns[2].Text = "Column 3";
listView1.Columns.Add(new ColumnHeader());
listView1.Columns[3].Text = "Column 4";
// Suspend control logic until form is done configuring form.
this.SuspendLayout();
// Add Items to the ListView control.
this.listView1.Items.AddRange(new ListViewItem[] {listViewItem1,
listViewItem2,
listViewItem3,
listViewItem4});
// Set the location and size of the ListView control.
this.listView1.Location = new Point(10, 10);
this.listView1.Name = "listView1";
this.listView1.Size = new Size(300, 100);
this.listView1.TabIndex = 0;
// Enable editing of the items in the ListView.
this.listView1.LabelEdit = true;
// Connect the ListView.ColumnClick event to the ColumnClick event handler.
this.listView1.ColumnClick += new ColumnClickEventHandler(ColumnClick);
// Initialize the form.
this.ClientSize = new Size(400, 400);
this.Controls.AddRange(new Control[] {this.listView1});
this.Name = "ListViewSortForm";
this.Text = "Sorted ListView Control";
// Resume layout of the form.
this.ResumeLayout(false);
}
// ColumnClick event handler.
private void ColumnClick(object o, ColumnClickEventArgs e)
{
// Set the ListViewItemSorter property to a new ListViewItemComparer
// object. Setting this property immediately sorts the
// ListView using the ListViewItemComparer object.
this.listView1.ListViewItemSorter = new ListViewItemComparer(e.Column);
}
[System.STAThreadAttribute()]
public static void Main()
{
Application.Run(new ListViewSortForm());
}
}
// Implements the manual sorting of items by columns.
class ListViewItemComparer : IComparer
{
private int col;
public ListViewItemComparer()
{
col = 0;
}
public ListViewItemComparer(int column)
{
col = column;
}
public int Compare(object x, object y)
{
return String.Compare(((ListViewItem)x).SubItems[col].Text, ((ListViewItem)y).SubItems[col].Text);
}
}
}
Imports System.Windows.Forms
Imports System.Drawing
Imports System.Collections
Namespace ListViewSortFormNamespace
Public Class ListViewSortForm
Inherits Form
Private listView1 As ListView
Public Sub New()
' Create ListView items to add to the control.
Dim listViewItem1 As New ListViewItem(New String() {"Banana", "a", "b", "c"}, -1, Color.Empty, Color.Yellow, Nothing)
Dim listViewItem2 As New ListViewItem(New String() {"Cherry", "v", "g", "t"}, -1, Color.Empty, Color.Red, New Font("Microsoft Sans Serif", 8.25F, FontStyle.Regular, GraphicsUnit.Point, CType(0, System.Byte)))
Dim listViewItem3 As New ListViewItem(New String() {"Apple", "h", "j", "n"}, -1, Color.Empty, Color.Lime, Nothing)
Dim listViewItem4 As New ListViewItem(New String() {"Pear", "y", "u", "i"}, -1, Color.Empty, Color.FromArgb(CType(192, System.Byte), CType(128, System.Byte), CType(156, System.Byte)), Nothing)
'Initialize the ListView control and add columns to it.
Me.listView1 = New ListView
' Set the initial sorting type for the ListView.
Me.listView1.Sorting = SortOrder.None
' Disable automatic sorting to enable manual sorting.
Me.listView1.View = View.Details
' Add columns and set their text.
Me.listView1.Columns.Add(New ColumnHeader)
Me.listView1.Columns(0).Text = "Column 1"
Me.listView1.Columns(0).Width = 100
listView1.Columns.Add(New ColumnHeader)
listView1.Columns(1).Text = "Column 2"
listView1.Columns.Add(New ColumnHeader)
listView1.Columns(2).Text = "Column 3"
listView1.Columns.Add(New ColumnHeader)
listView1.Columns(3).Text = "Column 4"
' Suspend control logic until form is done configuring form.
Me.SuspendLayout()
' Add Items to the ListView control.
Me.listView1.Items.AddRange(New ListViewItem() {listViewItem1, listViewItem2, listViewItem3, listViewItem4})
' Set the location and size of the ListView control.
Me.listView1.Location = New Point(10, 10)
Me.listView1.Name = "listView1"
Me.listView1.Size = New Size(300, 100)
Me.listView1.TabIndex = 0
' Enable editing of the items in the ListView.
Me.listView1.LabelEdit = True
' Connect the ListView.ColumnClick event to the ColumnClick event handler.
AddHandler Me.listView1.ColumnClick, AddressOf ColumnClick
' Initialize the form.
Me.ClientSize = New Size(400, 400)
Me.Controls.AddRange(New Control() {Me.listView1})
Me.Name = "ListViewSortForm"
Me.Text = "Sorted ListView Control"
' Resume layout of the form.
Me.ResumeLayout(False)
End Sub
' ColumnClick event handler.
Private Sub ColumnClick(ByVal o As Object, ByVal e As ColumnClickEventArgs)
' Set the ListViewItemSorter property to a new ListViewItemComparer
' object. Setting this property immediately sorts the
' ListView using the ListViewItemComparer object.
Me.listView1.ListViewItemSorter = New ListViewItemComparer(e.Column)
End Sub
End Class
' Implements the manual sorting of items by columns.
Class ListViewItemComparer
Implements IComparer
Private col As Integer
Public Sub New()
col = 0
End Sub
Public Sub New(ByVal column As Integer)
col = column
End Sub
Public Function Compare(ByVal x As Object, ByVal y As Object) As Integer _
Implements IComparer.Compare
Return [String].Compare(CType(x, ListViewItem).SubItems(col).Text, CType(y, ListViewItem).SubItems(col).Text)
End Function
End Class
End Namespace
Keterangan
Kelas ListView.ColumnHeaderCollection menyimpan header kolom yang ditampilkan dalam ListView kontrol saat View properti diatur ke Details. ColumnHeader Menyimpan ListView.ColumnHeaderCollection objek yang menentukan teks yang akan ditampilkan untuk kolom serta bagaimana header kolom ditampilkan dalam ListView kontrol saat menampilkan kolom. ListView Saat menampilkan kolom, item dan subitemnya ditampilkan di kolomnya sendiri. Untuk menentukan data subitem kolom mana yang ditampilkan di bawah, lihat ListViewItem.ListViewSubItemCollection kelas .
Ada sejumlah cara untuk menambahkan header kolom ke koleksi. Metode menambahkan Add header kolom tunggal ke koleksi. Untuk menambahkan sejumlah header kolom ke koleksi, Anda membuat array ColumnHeader objek dan meneruskannya ke AddRange metode . Jika Anda ingin menyisipkan header kolom di lokasi tertentu dalam koleksi, Anda bisa menggunakan metode .Insert Untuk menghapus header kolom, Anda dapat menggunakan Remove metode atau RemoveAt metode jika Anda tahu di mana header kolom berada di koleksi. Metode ini Clear memungkinkan Anda menghapus semua header kolom dari koleksi alih-alih menggunakan Remove metode untuk menghapus satu header kolom pada satu waktu.
Selain metode dan properti untuk menambahkan dan menghapus header kolom, ListView.ColumnHeaderCollection juga menyediakan metode untuk menemukan header kolom dalam koleksi. Metode ini Contains memungkinkan Anda menentukan apakah header kolom adalah anggota koleksi. Setelah Anda tahu bahwa header kolom terletak di koleksi, Anda dapat menggunakan IndexOf metode untuk menentukan di mana header kolom berada dalam koleksi.
Catatan
Perilaku tak terduga dapat dihasilkan ketika lebar gabungan semua kolom melebihi 32.768 piksel.
Konstruktor
ListView.ColumnHeaderCollection(ListView) |
Menginisialisasi instans baru kelas ListView.ColumnHeaderCollection. |
Properti
Count |
Mendapatkan jumlah item dalam koleksi. |
IsReadOnly |
Mendapatkan nilai yang menunjukkan apakah koleksi bersifat baca-saja. |
Item[Int32] |
Mendapatkan header kolom pada indeks yang ditentukan dalam koleksi. |
Item[String] |
Mendapatkan header kolom dengan kunci yang ditentukan dari koleksi. |
Metode
Add(ColumnHeader) |
Menambahkan yang sudah ada ColumnHeader ke koleksi. |
Add(String) |
Membuat dan menambahkan kolom dengan teks yang ditentukan ke koleksi. |
Add(String, Int32) |
Membuat dan menambahkan kolom dengan teks dan lebar yang ditentukan ke koleksi. |
Add(String, Int32, HorizontalAlignment) |
Menambahkan header kolom ke koleksi dengan pengaturan teks, lebar, dan perataan yang ditentukan. |
Add(String, String) |
Membuat dan menambahkan kolom dengan teks dan kunci yang ditentukan ke koleksi. |
Add(String, String, Int32) |
Membuat dan menambahkan kolom dengan teks, kunci, dan lebar yang ditentukan ke koleksi. |
Add(String, String, Int32, HorizontalAlignment, Int32) |
Membuat dan menambahkan kolom dengan kunci yang ditentukan, teks, lebar, dan indeks gambar yang diratakan ke koleksi. |
Add(String, String, Int32, HorizontalAlignment, String) |
Membuat dan menambahkan kolom dengan kunci yang ditentukan, teks, lebar, dan kunci gambar yang diratakan ke koleksi. |
AddRange(ColumnHeader[]) |
Menambahkan array header kolom ke koleksi. |
Clear() |
Menghapus semua header kolom dari koleksi. |
Contains(ColumnHeader) |
Menentukan apakah header kolom yang ditentukan terletak di koleksi. |
ContainsKey(String) |
Menentukan apakah kolom dengan kunci yang ditentukan terkandung dalam koleksi. |
Equals(Object) |
Menentukan apakah objek yang ditentukan sama dengan objek saat ini. (Diperoleh dari Object) |
GetEnumerator() |
Mengembalikan enumerator yang akan digunakan untuk melakukan iterasi melalui kumpulan header kolom. |
GetHashCode() |
Berfungsi sebagai fungsi hash default. (Diperoleh dari Object) |
GetType() |
Mendapatkan instans Type saat ini. (Diperoleh dari Object) |
IndexOf(ColumnHeader) |
Mengembalikan indeks, dalam koleksi, dari header kolom yang ditentukan. |
IndexOfKey(String) |
Menentukan indeks untuk kolom dengan kunci yang ditentukan. |
Insert(Int32, ColumnHeader) |
Menyisipkan header kolom yang ada ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String) |
Membuat header kolom baru dengan teks yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, Int32) |
Membuat header kolom baru dengan teks dan lebar awal yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, Int32, HorizontalAlignment) |
Membuat header kolom baru dan menyisipkannya ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, String) |
Membuat header kolom baru dengan teks dan kunci yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, String, Int32) |
Membuat header kolom baru dengan teks, kunci, dan lebar yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, String, Int32, HorizontalAlignment, Int32) |
Membuat header kolom baru dengan teks, kunci, lebar, dan indeks gambar yang diratakan yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
Insert(Int32, String, String, Int32, HorizontalAlignment, String) |
Membuat header kolom baru dengan teks, kunci, lebar, dan kunci gambar yang diratakan yang ditentukan, dan menyisipkan header ke dalam koleksi pada indeks yang ditentukan. |
MemberwiseClone() |
Membuat salinan dangkal dari yang saat ini Object. (Diperoleh dari Object) |
Remove(ColumnHeader) |
Menghapus header kolom yang ditentukan dari koleksi. |
RemoveAt(Int32) |
Menghapus header kolom pada indeks yang ditentukan dalam koleksi. |
RemoveByKey(String) |
Menghapus kolom dengan kunci yang ditentukan dari koleksi. |
ToString() |
Mengembalikan string yang mewakili objek saat ini. (Diperoleh dari Object) |
Implementasi Antarmuka Eksplisit
ICollection.CopyTo(Array, Int32) |
ColumnHeader Menyalin objek dalam ListView.ColumnHeaderCollection ke array, dimulai pada indeks array tertentu. |
ICollection.IsSynchronized |
Mendapatkan nilai yang menunjukkan apakah akses ke disinkronkan ListView.ColumnHeaderCollection (utas aman). |
ICollection.SyncRoot |
Mendapatkan objek yang dapat digunakan untuk menyinkronkan akses ke kumpulan kontrol. |
IList.Add(Object) |
ColumnHeader Menambahkan ke ListView. |
IList.Contains(Object) |
Menentukan apakah header kolom yang ditentukan terletak di koleksi. |
IList.IndexOf(Object) |
API ini mendukung infrastruktur produk dan tidak dimaksudkan untuk digunakan langsung dari kode Anda. Mengembalikan indeks, dalam koleksi, dari header kolom yang ditentukan. |
IList.Insert(Int32, Object) |
Menyisipkan header kolom yang ada ke dalam koleksi pada indeks yang ditentukan. |
IList.IsFixedSize |
Mendapatkan nilai yang menunjukkan apakah ListView.ColumnHeaderCollection memiliki ukuran tetap. |
IList.Item[Int32] |
Mendapatkan atau mengatur header kolom pada indeks yang ditentukan dalam koleksi. |
IList.Remove(Object) |
Menghapus header kolom yang ditentukan dari koleksi. |
Metode Ekstensi
Cast<TResult>(IEnumerable) |
Mentransmisikan elemen dari IEnumerable ke jenis yang ditentukan. |
OfType<TResult>(IEnumerable) |
Memfilter elemen berdasarkan IEnumerable jenis tertentu. |
AsParallel(IEnumerable) |
Mengaktifkan paralelisasi kueri. |
AsQueryable(IEnumerable) |
Mengonversi menjadi IEnumerableIQueryable. |