源代碼下載下傳位置:
http://pan.baidu.com/s/1qXrLehe
一、ListView類
1、常用的基本屬性:
(1)FullRowSelect:設定是否行選擇模式。(預設為false) 提示:隻有在Details視圖該屬性才有意義。
(2) GridLines:設定行和列之間是否顯示網格線。(預設為false)提示:隻有在Details視圖該屬性才有意義。
(3)AllowColumnReorder:設定是否可拖動列标頭來對改變列的順序。(預設為false)提示:隻有在Details視圖該屬性才有意義。
(4)View:擷取或設定項在控件中的顯示方式,包括Details、LargeIcon、List、SmallIcon、Tile(預設為 LargeIcon)
(5)MultiSelect:設定是否可以選擇多個項。(預設為false)
(6)HeaderStyle:擷取或設定列标頭樣式。
Clickable:列标頭的作用類似于按鈕,單擊時可以執行操作(例如排序)。
NonClickable:列标頭不響應滑鼠單擊。
None:不顯示列标頭。
(7)LabelEdit:設定使用者是否可以編輯控件中項的标簽,對于Detail視圖,隻能編輯行第一列的内容。(預設為false)
(8)CheckBoxes:設定控件中各項的旁邊是否顯示複選框。(預設為false)
(9)LargeImageList:大圖示集。提示:隻在LargeIcon視圖使用。
(10)SmallImageList:小圖示集。提示:隻有在SmallIcon視圖使用。
(11)StateImageList:圖像蒙闆。這些圖像蒙闆可用作LargeImageList和SmallImageList圖像的覆寫圖,這些圖像可用于訓示項的應用程式定義的狀态。(暫時不大懂)
(12)SelectedItems:擷取在控件中標明的項。
(13)CheckedItems:擷取控件中目前複選框選中的項。
(14)Soritng:對清單視圖的項進行排序。(預設為None)
Ascending:項按遞增順序排序。
Descending:項按遞減順序排序。
None:項未排序。
(15)Scrollable:設定當沒有足夠空間來顯示所有項時是否顯示滾動條。(預設為true)
(16)HoverSelection:設定當滑鼠指針懸停于項上時是否自動選擇項。(預設為false)
(17)HotTracking:設定當滑鼠指針經過項文本時,其外觀是否變為超連結的形式。(預設為false)
(18)HideSelection:設定標明項在控件沒焦點時是否仍突出顯示。(預設為false)
(19)ShowGroups:設定是否以分組方式顯示項。(預設為false);
(20)Groups:設定分組的對象集合。
(21)TopItem:擷取或設定控件中的第一個可見項,可用于定位。(效果類似于EnsureVisible方法)
2、常用方法:
(1)BeginUpdate:避免在調用EndUpdate 方法之前描述控件。當插入大量資料時,可以有效地避免控件閃爍,并能大大提高速度。
(2)EndUpdate:在BeginUpdate 方法挂起描述後,繼續描述清單視圖控件。(結束更新)
(3)EnsureVisible:清單視圖滾動定位到指定索引項的選項行。(效果類似于TopItem屬性)
(4)FindItemWithText:查找以給定文本值開頭的第一個 ListViewItem。
(5)FindNearestItem:按照指定的搜尋方向,從給定點開始查找下一個項。提示:隻有在LargeIcon或SmallIcon視圖才能使用該方法。
3、常用事件:
(1)AfterLabelEdit:當使用者編輯完項的标簽時發生,需要LabelEdit屬性為true。
(2)BeforeLabelEdit:當使用者開始編輯項的标簽時發生。
(3)ColumnClick:當使用者在清單視圖控件中單擊列标頭時發生。
二、ListView的五種視圖:
1、LargeIcon:每個項都顯示為一個最大化圖示,在它的下面有一個标簽。(效果見下圖)
2、SmallIcon:每個項都顯示為一個小圖示,在它的右邊帶一個标簽。(效果見下圖)
3、List:每個項都顯示為一個小圖示,在它的右邊帶一個标簽。各項排列在列中,沒有列标頭。(效果見下圖)
4、Details:可以顯示任意的列,但隻有第一列可以包含一個小圖示和标簽,其它的列項隻能顯示文字資訊,有清單頭。(效果見下圖)
5、Tile:每個項都顯示為一個完整大小的圖示,在它的右邊帶項标簽和子項資訊。(隻有Windows XP 和 Windows Server 2003 系列支援)
①Details視圖:
this.listView1.SmallImageList = this.imageList1; //将listView的圖示集與imageList1綁定
(1)清單頭建立(記得,需要先建立清單頭)
ColumnHeader ch= new ColumnHeader();
nbsp;ch.Text = "列标題1"; //設定列标題
ch.Width = 120; //設定列寬度
ch.TextAlign = HorizontalAlignment.Left; //設定列的對齊方式
this.listView1.Columns.Add(ch); //将列頭添加到ListView控件。
或者
```csharp
this.listView1.Columns.Add("列标題1", 120, HorizontalAlignment.Left); //一步添加
(2)添加資料項
this.listView1.BeginUpdate(); //資料更新,UI暫時挂起,直到EndUpdate繪制控件,可以有效避免閃爍并大大提高加載速度
for (int i = 0; i < 10; i++) //添加10行資料
{
ListViewItem lvi = new ListViewItem();
lvi.ImageIndex = i; //通過與imageList綁定,顯示imageList中第i項圖示
lvi.Text = "subitem" + i;
lvi.SubItems.Add("第2列,第"+i+"行");
lvi.SubItems.Add("第3列,第"+i+"行");
this.listView1.Items.Add(lvi);
}
this.listView1.EndUpdate(); //結束資料處理,UI界面一次性繪制。
(3)顯示項
foreach (ListViewItem item in this.listView1.Items)
{
for (int i = 0; i < item.SubItems.Count; i++)
{
MessageBox.Show(item.SubItems[i].Text);
}
}
(4)移除某項
foreach (ListViewItem lvi in listView1.SelectedItems) //選中項周遊
{
listView1.Items.RemoveAt(lvi.Index); // 按索引移除
//listView1.Items.Remove(lvi); //按項移除
}
5)行高設定(利用imageList實作)
ImageList imgList = new ImageList();
imgList.ImageSize = new Size(1, 20);// 設定行高 20 //分别是寬和高
listView1.SmallImageList = imgList; //這裡設定listView的SmallImageList ,用imgList将其撐大
(6)清空
this.listView1.Clear(); //從控件中移除所有項和列(包括清單頭)。
this.listView1.Items.Clear(); //隻移除所有的項。
②largeIcon視圖:
this.listView1.View = View.LargeIcon;
this.listView1.LargeImageList = this.imageList2;
this.listView1.BeginUpdate();
for (int i = 0; i < 10; i++)
{
ListViewItem lvi = new ListViewItem();
lvi.ImageIndex = i;
lvi.Text = "item" + i;
this.listView1.Items.Add(lvi);
}
this.listView1.EndUpdate();
③SmallIcon視圖:
this.listView1.View = View.SmallIcon;
this.listView1.SmallImageList= this.imageList1;
this.listView1.BeginUpdate();
for (int i = 0; i < 10; i++)
{
ListViewItem lvi = new ListViewItem();
lvi.ImageIndex = i;
lvi.Text = "item" + i;
this.listView1.Items.Add(lvi);
}
this.listView1.EndUpdate();
④List視圖:
this.listView1.View = View.List;
this.listView1.SmallImageList= this.imageList1;
this.listView1.BeginUpdate();
for (int i = 0; i < 10; i++)
{
ListViewItem lvi = new ListViewItem();
lvi.ImageIndex = i;
lvi.Text = "item" + i;
this.listView1.Items.Add(lvi);
}
this.listView1.EndUpdate();
三、其它應用
1、分組:
ListViewGroup man_lvg = new ListViewGroup(); //建立男生分組
man_lvg.Header = "男生"; //設定組的标題。
//man_lvg.Name = "man"; //設定組的名稱。
man_lvg.HeaderAlignment = HorizontalAlignment.Left; //設定組标題文本的對齊方式。(預設為Left)
ListViewGroup women_lvg = new ListViewGroup(); //建立女生分組
women_lvg.Header = "女生";
//women_lvg.Name = "women";
women_lvg.HeaderAlignment = HorizontalAlignment.Center; //組标題居中對齊
this.listView1.Groups.Add(man_lvg); //把男生分組添加到listview中
this.listView1.Groups.Add(women_lvg); //把男生分組添加到listview中
this.listView1.ShowGroups = true; //記得要設定ShowGroups屬性為true(預設是false),否則顯示不出分組
for (int i = 0; i < 5; i++)
{
ListViewItem lvi = new ListViewItem();
lvi.ImageIndex = i;
lvi.Text = "item"+i;
lvi.ForeColor = Color.Blue; //設定行顔色
lvi.SubItems.Add("第2列,第"+i+"行");
lvi.SubItems.Add("第3列,第"+i+"行");
man_lvg.Items.Add(lvi); //分組添加子項
// 或 lvi.Group = man_lvg; //分組添加子項
this.listView1.Items.Add(lvi);
}
2、查找文本(隻能查找到比對字首的文本且隻能找出第一個符合的項):
ListViewItem foundItem= this.listView1.FindItemWithText(this.textBox1.Text,true,0); //參數1:要查找的文本;參數2:是否子項也要查找;參數3:開始查找位置
if (foundItem != null)
{
this.listView1.TopItem = foundItem; //定位到該項
foundItem.ForeColor = Color.Red;
}
轉自:http://blog.csdn.net/czw2010/article/details/7910324