C# ListView用法詳解 很完整


一、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)列表頭創建(記得,需要先創建列表頭)       

[csharp]  view plain copy
 
 
 
  1. ColumnHeader  ch= new ColumnHeader(); 
  2.  
  3. nbsp;ch.Text = "列標題1";   //設置列標題 
  4.  
  5. ch.Width = 120;    //設置列寬度 
  6.  
  7. ch.TextAlign = HorizontalAlignment.Left;   //設置列的對齊方式 
  8.  
  9. this.listView1.Columns.Add(ch);   //將列頭添加到ListView控件。 
[csharp]  view plain copy
 
 
 
  1. ColumnHeader  ch= new ColumnHeader();  
  2.   
  3. ch.Text = "列標題1";   //設置列標題  
  4.   
  5. ch.Width = 120;    //設置列寬度   
  6.   
  7. ch.TextAlign = HorizontalAlignment.Left;   //設置列的對齊方式  
  8.   
  9. this.listView1.Columns.Add(ch);    //將列頭添加到ListView控件。  
[csharp]  view plain  copy
 
  1. ColumnHeader  ch= new ColumnHeader();  
  2.   
  3. ch.Text = "列標題1";   //設置列標題  
  4.   
  5. ch.Width = 120;    //設置列寬度  
  6.   
  7. ch.TextAlign = HorizontalAlignment.Left;   //設置列的對齊方式  
  8.   
  9. this.listView1.Columns.Add(ch);    //將列頭添加到ListView控件。  

                          或者

[csharp]  view plain copy
 
 
 
  1. this.listView1.Columns.Add("列標題1", 120,  HorizontalAlignment.Left);//一步添加 
[csharp]  view plain copy
 
 
 
  1. this.listView1.Columns.Add("列標題1", 120,  HorizontalAlignment.Left); //一步添加  
[csharp]  view plain  copy
 
  1. this.listView1.Columns.Add("列標題1", 120,  HorizontalAlignment.Left); //一步添加  

       (2)添加數據項       

[csharp]  view plain copy
 
 
 
  1. this.listView1.BeginUpdate();  //數據更新,UI暫時掛起,直到EndUpdate繪制控件,可以有效避免閃爍並大大提高加載速度 
  2.  
  3. for (int i = 0; i < 10; i++)  //添加10行數據 
  4.      ListViewItem lvi = new ListViewItem(); 
  5.  
  6.      lvi.ImageIndex = i;     //通過與imageList綁定,顯示imageList中第i項圖標 
  7.  
  8.      lvi.Text = "subitem" + i; 
  9.  
  10.      lvi.SubItems.Add("第2列,第"+i+"行"); 
  11.  
  12.      lvi.SubItems.Add("第3列,第"+i+"行"); 
  13.  
  14.      this.listView1.Items.Add(lvi); 
  15.  
  16. this.listView1.EndUpdate();  //結束數據處理,UI界面一次性繪制。 
[csharp]  view plain copy
 
 
 
  1. this.listView1.BeginUpdate();   //數據更新,UI暫時掛起,直到EndUpdate繪制控件,可以有效避免閃爍並大大提高加載速度  
  2.   
  3. for (int i = 0; i < 10; i++)   //添加10行數據  
  4. {  
  5.     ListViewItem lvi = new ListViewItem();  
  6.   
  7.     lvi.ImageIndex = i;     //通過與imageList綁定,顯示imageList中第i項圖標  
  8.   
  9.     lvi.Text = "subitem" + i;  
  10.   
  11.     lvi.SubItems.Add("第2列,第"+i+"行");  
  12.   
  13.     lvi.SubItems.Add("第3列,第"+i+"行");  
  14.   
  15.     this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  //結束數據處理,UI界面一次性繪制。  
[csharp]  view plain  copy
 
  1. this.listView1.BeginUpdate();   //數據更新,UI暫時掛起,直到EndUpdate繪制控件,可以有效避免閃爍並大大提高加載速度  
  2.   
  3. for (int i = 0; i < 10; i++)   //添加10行數據  
  4. {  
  5.     ListViewItem lvi = new ListViewItem();  
  6.   
  7.     lvi.ImageIndex = i;     //通過與imageList綁定,顯示imageList中第i項圖標  
  8.   
  9.     lvi.Text = "subitem" + i;  
  10.   
  11.     lvi.SubItems.Add("第2列,第"+i+"行");  
  12.   
  13.     lvi.SubItems.Add("第3列,第"+i+"行");  
  14.   
  15.     this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  //結束數據處理,UI界面一次性繪制。  

          (3)顯示項

[csharp]  view plain copy
 
 
 
  1. foreach (ListViewItem itemin this.listView1.Items) 
  2.       for (int i = 0; i < item.SubItems.Count; i++) 
  3.       { 
  4.           MessageBox.Show(item.SubItems[i].Text); 
  5.       } 
[csharp]  view plain copy
 
 
 
  1. foreach (ListViewItem item in this.listView1.Items)  
  2. {  
  3.       for (int i = 0; i < item.SubItems.Count; i++)  
  4.       {  
  5.           MessageBox.Show(item.SubItems[i].Text);  
  6.       }  
  7. }  
[csharp]  view plain  copy
 
  1. foreach (ListViewItem item in this.listView1.Items)  
  2. {  
  3.       for (int i = 0; i < item.SubItems.Count; i++)  
  4.       {  
  5.           MessageBox.Show(item.SubItems[i].Text);  
  6.       }  
  7. }  

           (4)移除某項

[csharp]  view plain copy
 
 
 
  1. foreach (ListViewItem lviin listView1.SelectedItems)  //選中項遍歷 
  2.       listView1.Items.RemoveAt(lvi.Index); // 按索引移除 
  3.       //listView1.Items.Remove(lvi);   //按項移除 
  4. }    
[csharp]  view plain copy
 
 
 
  1. foreach (ListViewItem lvi in listView1.SelectedItems)  //選中項遍歷  
  2. {  
  3.       listView1.Items.RemoveAt(lvi.Index); // 按索引移除  
  4.       //listView1.Items.Remove(lvi);   //按項移除  
  5. }     
[csharp]  view plain  copy
 
  1. foreach (ListViewItem lvi in listView1.SelectedItems)  //選中項遍歷  
  2. {  
  3.       listView1.Items.RemoveAt(lvi.Index); // 按索引移除  
  4.       //listView1.Items.Remove(lvi);   //按項移除  
  5. }     

          (5)行高設置(利用imageList實現)

[csharp]  view plain copy
 
 
 
  1. ImageList imgList = new ImageList(); 
  2.  
  3. imgList.ImageSize = new Size(1, 20);// 設置行高 20 //分別是寬和高 
  4.  
  5. listView1.SmallImageList = imgList; //這里設置listView的SmallImageList ,用imgList將其撐大 
[csharp]  view plain copy
 
 
 
  1. ImageList imgList = new ImageList();  
  2.   
  3. imgList.ImageSize = new Size(1, 20);// 設置行高 20 //分別是寬和高  
  4.   
  5. listView1.SmallImageList = imgList; //這里設置listView的SmallImageList ,用imgList將其撐大  
[csharp]  view plain  copy
 
  1. ImageList imgList = new ImageList();  
  2.   
  3. imgList.ImageSize = new Size(1, 20);// 設置行高 20 //分別是寬和高  
  4.   
  5. listView1.SmallImageList = imgList; //這里設置listView的SmallImageList ,用imgList將其撐大  

          (6)清空

[csharp]  view plain copy
 
 
 
  1. this.listView1.Clear(); //從控件中移除所有項和列(包括列表頭)。 
  2.  
  3. this.listView1.Items.Clear(); //只移除所有的項。 
[csharp]  view plain copy
 
 
 
  1. this.listView1.Clear();  //從控件中移除所有項和列(包括列表頭)。  
  2.   
  3. this.listView1.Items.Clear();  //只移除所有的項。  
[csharp]  view plain  copy
 
  1. this.listView1.Clear();  //從控件中移除所有項和列(包括列表頭)。  
  2.   
  3. this.listView1.Items.Clear();  //只移除所有的項。  

 

運行效果:

        ②largeIcon視圖:

[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.LargeIcon; 
  2.  
  3. this.listView1.LargeImageList =this.imageList2; 
  4.  
  5. this.listView1.BeginUpdate(); 
  6.  
  7. for (int i = 0; i < 10; i++) 
  8.       ListViewItem lvi = new ListViewItem(); 
  9.  
  10.       lvi.ImageIndex = i; 
  11.  
  12.       lvi.Text = "item" + i; 
  13.  
  14.       this.listView1.Items.Add(lvi); 
  15.  
  16. this.listView1.EndUpdate(); 
[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.LargeIcon;  
  2.   
  3. this.listView1.LargeImageList = this.imageList2;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7.  for (int i = 0; i < 10; i++)  
  8.  {  
  9.       ListViewItem lvi = new ListViewItem();  
  10.   
  11.       lvi.ImageIndex = i;  
  12.   
  13.       lvi.Text = "item" + i;  
  14.   
  15.       this.listView1.Items.Add(lvi);  
  16.  }  
  17.   
  18.  this.listView1.EndUpdate();  
[csharp]  view plain  copy
 
  1. this.listView1.View = View.LargeIcon;  
  2.   
  3. this.listView1.LargeImageList = this.imageList2;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7.  for (int i = 0; i < 10; i++)  
  8.  {  
  9.       ListViewItem lvi = new ListViewItem();  
  10.   
  11.       lvi.ImageIndex = i;  
  12.   
  13.       lvi.Text = "item" + i;  
  14.   
  15.       this.listView1.Items.Add(lvi);  
  16.  }  
  17.   
  18.  this.listView1.EndUpdate();  

運行效果:

          ③SmallIcon視圖:

[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.SmallIcon; 
  2.  
  3. this.listView1.SmallImageList=this.imageList1; 
  4.  
  5. this.listView1.BeginUpdate(); 
  6.  
  7. for (int i = 0; i < 10; i++) 
  8.      ListViewItem lvi = new ListViewItem(); 
  9.  
  10.       lvi.ImageIndex = i; 
  11.  
  12.       lvi.Text = "item" + i; 
  13.  
  14.       this.listView1.Items.Add(lvi); 
  15.  
  16. this.listView1.EndUpdate(); 
[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.SmallIcon;  
  2.   
  3. this.listView1.SmallImageList= this.imageList1;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7. for (int i = 0; i < 10; i++)  
  8. {  
  9.      ListViewItem lvi = new ListViewItem();  
  10.   
  11.       lvi.ImageIndex = i;  
  12.   
  13.       lvi.Text = "item" + i;  
  14.   
  15.       this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  
[csharp]  view plain  copy
 
  1. this.listView1.View = View.SmallIcon;  
  2.   
  3. this.listView1.SmallImageList= this.imageList1;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7. for (int i = 0; i < 10; i++)  
  8. {  
  9.      ListViewItem lvi = new ListViewItem();  
  10.   
  11.       lvi.ImageIndex = i;  
  12.   
  13.       lvi.Text = "item" + i;  
  14.   
  15.       this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  

運行效果:

           ④List視圖:   

[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.List; 
  2.  
  3. this.listView1.SmallImageList=this.imageList1; 
  4.  
  5. this.listView1.BeginUpdate(); 
  6.  
  7. for (int i = 0; i < 10; i++) 
  8.      ListViewItem lvi = new ListViewItem(); 
  9.  
  10.      lvi.ImageIndex = i; 
  11.  
  12.      lvi.Text = "item" + i; 
  13.  
  14.      this.listView1.Items.Add(lvi); 
  15.  
  16. this.listView1.EndUpdate(); 
[csharp]  view plain copy
 
 
 
  1. this.listView1.View = View.List;  
  2.   
  3. this.listView1.SmallImageList= this.imageList1;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7. for (int i = 0; i < 10; i++)  
  8. {  
  9.      ListViewItem lvi = new ListViewItem();  
  10.   
  11.      lvi.ImageIndex = i;  
  12.   
  13.      lvi.Text = "item" + i;  
  14.   
  15.      this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  
[csharp]  view plain  copy
 
  1. this.listView1.View = View.List;  
  2.   
  3. this.listView1.SmallImageList= this.imageList1;  
  4.   
  5. this.listView1.BeginUpdate();  
  6.   
  7. for (int i = 0; i < 10; i++)  
  8. {  
  9.      ListViewItem lvi = new ListViewItem();  
  10.   
  11.      lvi.ImageIndex = i;  
  12.   
  13.      lvi.Text = "item" + i;  
  14.   
  15.      this.listView1.Items.Add(lvi);  
  16. }  
  17.   
  18. this.listView1.EndUpdate();  

運行效果:

 

 

     三、其它應用

         1、分組:      

[csharp]  view plain copy
 
 
 
  1. ListViewGroup man_lvg = new ListViewGroup(); //創建男生分組 
  2.  
  3. man_lvg.Header = "男生";  //設置組的標題。 
  4.  
  5. //man_lvg.Name = "man";   //設置組的名稱。 
  6.  
  7. man_lvg.HeaderAlignment = HorizontalAlignment.Left;   //設置組標題文本的對齊方式。(默認為Left) 
  8.  
  9. ListViewGroup women_lvg = new ListViewGroup(); //創建女生分組 
  10.  
  11. women_lvg.Header = "女生"; 
  12.  
  13. //women_lvg.Name = "women"; 
  14.  
  15. women_lvg.HeaderAlignment = HorizontalAlignment.Center;   //組標題居中對齊 
  16.  
  17. this.listView1.Groups.Add(man_lvg);   //把男生分組添加到listview中 
  18.  
  19. this.listView1.Groups.Add(women_lvg);  //把男生分組添加到listview中 
  20.  
  21. this.listView1.ShowGroups =true;  //記得要設置ShowGroups屬性為true(默認是false),否則顯示不出分組 
  22.  
  23. for (int i = 0; i < 5; i++) 
  24.      ListViewItem lvi = new ListViewItem(); 
  25.  
  26.      lvi.ImageIndex = i; 
  27.  
  28.      lvi.Text = "item"+i; 
  29.  
  30.      lvi.ForeColor = Color.Blue;  //設置行顏色 
  31.  
  32.      lvi.SubItems.Add("第2列,第"+i+"行"); 
  33.  
  34.      lvi.SubItems.Add("第3列,第"+i+"行"); 
  35.  
  36.      man_lvg.Items.Add(lvi);   //分組添加子項 
  37.  
  38.      // 或 lvi.Group = man_lvg;  //分組添加子項 
  39.  
  40.      this.listView1.Items.Add(lvi); 
[csharp]  view plain copy
 
 
 
  1.  ListViewGroup man_lvg = new ListViewGroup();  //創建男生分組  
  2.   
  3.  man_lvg.Header = "男生";  //設置組的標題。  
  4.   
  5.  //man_lvg.Name = "man";   //設置組的名稱。  
  6.   
  7.  man_lvg.HeaderAlignment = HorizontalAlignment.Left;   //設置組標題文本的對齊方式。(默認為Left)  
  8.   
  9.  ListViewGroup women_lvg = new ListViewGroup();  //創建女生分組  
  10.   
  11.  women_lvg.Header = "女生";  
  12.   
  13.  //women_lvg.Name = "women";   
  14.   
  15.  women_lvg.HeaderAlignment = HorizontalAlignment.Center;   //組標題居中對齊  
  16.   
  17.  this.listView1.Groups.Add(man_lvg);    //把男生分組添加到listview中  
  18.   
  19.  this.listView1.Groups.Add(women_lvg);   //把男生分組添加到listview中  
  20.   
  21.  this.listView1.ShowGroups = true;  //記得要設置ShowGroups屬性為true(默認是false),否則顯示不出分組  
  22.   
  23.  for (int i = 0; i < 5; i++)  
  24.  {  
  25.      ListViewItem lvi = new ListViewItem();  
  26.   
  27.      lvi.ImageIndex = i;  
  28.   
  29.      lvi.Text = "item"+i;  
  30.   
  31.      lvi.ForeColor = Color.Blue;  //設置行顏色  
  32.   
  33.      lvi.SubItems.Add("第2列,第"+i+"行");  
  34.   
  35.      lvi.SubItems.Add("第3列,第"+i+"行");  
  36.   
  37.      man_lvg.Items.Add(lvi);   //分組添加子項  
  38.   
  39.      // 或 lvi.Group = man_lvg;  //分組添加子項  
  40.   
  41.      this.listView1.Items.Add(lvi);  
  42. }  
[csharp]  view plain  copy
 
  1.  ListViewGroup man_lvg = new ListViewGroup();  //創建男生分組  
  2.   
  3.  man_lvg.Header = "男生";  //設置組的標題。  
  4.   
  5.  //man_lvg.Name = "man";   //設置組的名稱。  
  6.   
  7.  man_lvg.HeaderAlignment = HorizontalAlignment.Left;   //設置組標題文本的對齊方式。(默認為Left)  
  8.   
  9.  ListViewGroup women_lvg = new ListViewGroup();  //創建女生分組  
  10.   
  11.  women_lvg.Header = "女生";  
  12.   
  13.  //women_lvg.Name = "women";  
  14.   
  15.  women_lvg.HeaderAlignment = HorizontalAlignment.Center;   //組標題居中對齊  
  16.   
  17.  this.listView1.Groups.Add(man_lvg);    //把男生分組添加到listview中  
  18.   
  19.  this.listView1.Groups.Add(women_lvg);   //把男生分組添加到listview中  
  20.   
  21.  this.listView1.ShowGroups = true;  //記得要設置ShowGroups屬性為true(默認是false),否則顯示不出分組  
  22.   
  23.  for (int i = 0; i < 5; i++)  
  24.  {  
  25.      ListViewItem lvi = new ListViewItem();  
  26.   
  27.      lvi.ImageIndex = i;  
  28.   
  29.      lvi.Text = "item"+i;  
  30.   
  31.      lvi.ForeColor = Color.Blue;  //設置行顏色  
  32.   
  33.      lvi.SubItems.Add("第2列,第"+i+"行");  
  34.   
  35.      lvi.SubItems.Add("第3列,第"+i+"行");  
  36.   
  37.      man_lvg.Items.Add(lvi);   //分組添加子項  
  38.   
  39.      // 或 lvi.Group = man_lvg;  //分組添加子項  
  40.   
  41.      this.listView1.Items.Add(lvi);  
  42. }  

運行效果:

          2、查找文本(只能查找到匹配前綴的文本且只能找出第一個符合的項):

[csharp]  view plain copy print ?
 
 
 
  1. ListViewItem foundItem= this.listView1.FindItemWithText(this.textBox1.Text,true,0);   //參數1:要查找的文本;參數2:是否子項也要查找;參數3:開始查找位置 
  2.  
  3. if (foundItem != null) 
  4.  
  5.    this.listView1.TopItem = foundItem; //定位到該項 
  6.  
  7.    foundItem.ForeColor = Color.Red;   

 

二、
1.定義
 
把它拽進來,系統會自動在Designer.cs里添加一個  this.listView1 = new System.Windows.Forms.ListView();
 
2.初始化,確定模式,確定列
 
 
InitializeComponent()里系統首先自動完成對它的初始化操作
而用戶自定義的初始化操作我建議寫在Form構造函數里跟在InitializeComponent()后面。
原因是一旦listView有變動,系統自動調整InitializeComponent()內容,可能會自動刪除掉用戶寫的部分。
 
 
this.listView1.Columns.Add("學生序號");
this.listView1.Columns.Add("學生姓名");
this.listView1.Columns.Add("學生學號");
 
這些是主要的,確定一共幾個列
 
this.listView1.View = System.Windows.Forms.View.Details;
如果不寫這句,那么加的列壓根顯示不出來。必須寫。
 
我們先研究Details模式下的ListView用法,要這樣對listView的View屬性賦值。
 
很多教程都直接寫this.listView1.View =View.Details;
 
盡管using System.Windows.Forms 但不管用。還是寫全吧。
 
System.Windows.Forms.View是個枚舉 public enum View;
 
LargeIcon 每個項都顯示為一個最大化圖標,在它的下面有一個標簽。
Details 每個項顯示在不同的行上,並帶有關於列中所排列的各項的進一步信息。最左邊的列包含一個小圖標和標簽,后面的列包含應用程序指定的子項。列顯示一個標頭,它可以顯示列的標題。用戶可以在運行時調整各列的大小。
SmallIcon 每個項都顯示為一個小圖標,在它的右邊帶一個標簽。
List 每個項都顯示為一個小圖標,在它的右邊帶一個標簽。各項排列在列中,沒有列標頭。
Tile 每個項都顯示為一個完整大小的圖標,在它的右邊帶項標簽和子項信息。顯示的子項信息由應用程序指定。此視圖僅在下面的平台上受支持:Windows XP 和 Windows Server 2003 系列。在之前的操作系統上,此值被忽略,並且 ListView 控件在 LargeIcon 視圖中顯示。
 
 
 
 
listView1.FullRowSelect = true;
this.listView1.GridLines = true;
listView1.LabelEdit = true;
// Allow the user to rearrange columns.
listView1.AllowColumnReorder = true;
// Display check boxes.
listView1.CheckBoxes = true;
listView1.Sorting = SortOrder.Ascending;
//Create three items and three sets of subitems for each item.
 
另外還有很多自定義屬性可以配,什么選中啦,線條啦,自己試試吧
 
 
默認的列寬不大,標題頭顯示總不全
 
listView1.Columns[0].Width = 100;
listView1.Columns[1].Width = 100;
 
Columns數組本身可以引用每個列
 
 
3. 增加行
 
 
增加行操作主要分成兩種,一種是直接字符串添加,一種是借助ListViewItem對象添加
 
 
一.直接添加法
 
this.listView1.Items.Add("A1");  
這是指給這個控件表添加一個新的行,同時把新行的第一列數據設為A1,此時這個新行內的元素集合就是this.listView1.Item[0]
this.listView1.Items[0].SubItems.Add("A2");
這是給剛添加的第一行,也就是this.listView1.Item[0]添加第二列數據A2.如果說Items在行的層次增加,Item[i].SubItems才真正對應單元格操作。
this.listView1.Items[0].SubItems.Add("A3");
 
此時第一行添加工作結束,白叔叔告你,第一行內容為 A1---A2---A3
 
this.listView1.Items.Add("B1");  此時再Add,相當於加了第二行數據,同時添加了第二行第一列的單元格內容。
this.listView1.Items[1].SubItems.Add("B2"); Items表示行,所以第二行就是Items[1],行標從0起始。
this.listView1.Items[1].SubItems.Add("B3");
 
第二行結束,內容B1---B2---B3
 
 
二.ListViewItem間接添加法。
 
方法是先創建一個行對象
再把這個行對象添加給this.listView1.Items
 
 
ListViewItem li的初始化又有兩種方法,大同小異
 
一種是
 
ListViewItem li=new ListViewItem("A1");
 
另一種是
 
ListViewItem li=new ListViewItem();
li.Text="A1";
 
作用是相同的,白叔叔不騙你。
 
都是初始化一個“行對象”,同時把這個行對象的第一列單元格初始化為"A1"
 
li.SubItems.Add("abc");
li.SubItems.Add("cde");
 
然后把第二列和第三列內容加上。
 
this.listView1.Items.Add(li); 這句話在前幾句話之前也行,之后也行
 
可以先加進listView再添加子項,也可以都加全了子項再加進listView
 
li可以復用,不斷初始化成新的行進行添加。
 
 
 
關於項的選取和數據的采集
 
首先,現階段ListView項的選取分成兩類
一種是用左鍵選取,適用的方法是SelectedItems和SelectedIndices
另一種是通過復選框勾選的選取CheckedItems我沒用過,暫時不討論,但事實上類同第一種

左鍵選取

1.首先要判斷有沒有項被選中變藍,如果不判斷那么用到SelectedItem[i]時會因為沒有合適結果報錯。
 if (this.listView1.SelectedItems.Count > 0)

2.  SelectedItems是獲取選中的行的集合,也就是說支持多行選擇,它是多行的集合。
this.textBox2.Text = this.listView1.SelectedItems[0].Text;
這里的索引[0]並不是指原列表的第一行,而是將全體被選中行當做一個集合,在被選中行中的第一被選行。
此時返回的是該行第一列的單元格內容。
this.textBox2.Text = this.listView1.SelectedItems[0].SubItems[0].Text;
用SubItems[0]兩者得到的結果是一樣的,也是第一被選行的第一列。
this.textBox2.Text = this.listView1.SelectedItems[0].SubItems[1].Text;
上面是第一被選行的第二列,以此類推。

3.  SelectedIndices是返回選中行的索引值int
this.listView1.SelectedIndices[i]也是將選中行當做整體,用i去定位。

 

如果只對選取單行做獲取判斷listView1.FocusedItem.Text估計效率更高


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM