C#(在TreeView中使用CheckBox)

樹結構中的節點共有兩層(父節點是分類名稱子節點是屬於該類的項的名稱)都是從數據庫中讀出而且是在讀出的過程中將具體的數據項名稱進行分類的。要想實現:treeview的AfterCheck事件中的:
    1.父節點勾選則子節點全部勾選
    2.父節點不勾選則子節點全部不勾選
    3.子節點全部不勾選則父節點不夠選而且父節點的文本呈黑色
    4.子節點部分勾選則父節點不勾選而且文本呈灰色
    5.子節點全部勾選則父節點被勾選而且文本呈黑色

private bool nextCheck(TreeNode n)//判斷同級的節點是否全選
  {
   if(n.Checked==false)
    return false;
   if(n.NextNode == null)
    return true;
   return this.nextCheck(n.NextNode);
  }

  private bool nextNotCheck(TreeNode n)//判斷同級的節點是否全不選
  {
   if(n.Checked==true)
    return false;
   if(n.NextNode == null)
    return true;
   return this.nextNotCheck(n.NextNode);
  }


  bool bCheck=false;

  private void treeView1_AfterCheck(object sender, System.Windows.Forms.TreeViewEventArgs e)
  {
   if(bCheck)
    return;
   
   ///////////////////////////要求父節點被勾選則子節點全部被勾選;父節點不被勾選則子節點全部不被勾選////////////////////////
   if(e.Node.Parent==null&&e.Node.Nodes.Count!=0)//父節點
   { 

    if(e.Node.Checked==true)
    {
     for(int i=0;i<e.Node.Nodes.Count;i++)
     {
      if(e.Node.Nodes[i].Checked==false)
      {
       bCheck=true;
       e.Node.Nodes[i].Checked=true;//父節點選中則子節點全部選中
      }
     }
     e.Node.ForeColor=Color.Black;
     bCheck=false;

    }
    if(e.Node.Checked==false)
    {
     for(int i=0;i<e.Node.Nodes.Count;i++)
     {
      
      bCheck=true;
      e.Node.Nodes[i].Checked=false;//父節點不選中則子節點全部不選中
     
     }
     e.Node.ForeColor=Color.Black;
     bCheck=false;
    }
   
    return; 
    
   }


   ///要求子節點全部不勾選則父節點不被勾選且文本呈黑色;子節點部分被勾選則父節點不被勾選文本呈藍色;子節點全部勾選則父節點被勾選且文本呈黑色///////
   if(e.Node.Parent!=null&&e.Node.Nodes.Count==0)//子節點
   {
    if(nextCheck(e.Node.Parent.FirstNode)==true)//全部勾選
    {
     bCheck=true;
     e.Node.Parent.Checked =true;
     e.Node.Parent.ForeColor =Color.Black ;
    }

    else if(nextNotCheck(e.Node.Parent.FirstNode)==true)//全部不勾選
    {
     bCheck=true;
     e.Node.Parent.Checked =false;
     e.Node.Parent.ForeColor =Color.Black ;
    }
    else
    {
     bCheck=true;
     e.Node.Parent.Checked =false;
     e.Node.Parent.ForeColor =Color.Gray;
    }
     bCheck=false;
    return;
   }
  }
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

         以下是遞歸的多極節點的實現

////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

 private void treeView1_AfterCheck(object sender, System.Windows.Forms.TreeViewEventArgs e)
  {
   if( e.Action != TreeViewAction.Unknown )
   {
    //Event call by mouse or key-press
    SetNodeCheckStatus( e.Node, e.Node.Checked );
   }
  }
  private void SetNodeCheckStatus( TreeNode tn, bool Checked )
  {
   if( tn == null ) return;
   // Check children nodes
   foreach (TreeNode tnChild in tn.Nodes)
   {
    tnChild.Checked = Checked;
    SetNodeCheckStatus( tnChild, Checked );
   }
   // Set parent check status
   TreeNode tnParent = tn;
   int nNodeCount = 0;
   while( tnParent.Parent != null )
   {
    tnParent = (TreeNode)(tnParent.Parent);
    nNodeCount = 0;
    foreach( TreeNode tnTemp in tnParent.Nodes )
     if( tnTemp.Checked == Checked )
      nNodeCount++;
    if( nNodeCount == tnParent.Nodes.Count )
     tnParent.Checked = Checked;
    else
     tnParent.Checked = false;
   }
  }

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章