zoukankan      html  css  js  c++  java
  • 艾伟_转载:TreeView节点定位的另外一种方法TreeNode.FromHandle 狼人:

      Winform 里面的TreeView是一种常见的、功能强大的控件,一般的使用大家可能都是比较熟悉的了,估计我们大多数做定位节点的时候,一般都是采用循环查找的方法。如下面的方法所示

     foreach (TreeNode node in this.TreeView1.Nodes)
    {
    if (node.Text == "要找的节点名称")
    {
    return node;
    }
    return null;
    }

      另外还有一种方法是使      

      用TreeNode.FromHandle方法来快速定位节点,为了说明如何使用,我们假设有这么一个场景,有一个集团,集团里面有很多公司,每个公司又有一些子公司,

      我们需要在每个子公司下面增加一些设备节点或者人员节点。那我们应该如何处理这些节点的显示和定位呢?

      首先我们在添加集团这些公司及子公司节点的时候,分别记录这些公司及子公司的树节点信息,放到内存列表中。代码如下所示。

     TreeView treeView = this.TreeView1;
    treeView.Nodes.Clear();
    foreach (string key in groupList.Keys)
    {
    TreeNode node
    = treeView.Nodes.Add(key, key, 0);
    if (!companyHandleDict.ContainsKey(key))
    {
    companyHandleDict.Add(key, node.Handle);
    }
    }

    foreach (string key in groupList.Keys)
    {
    foreach (string subKey in groupList[key].Keys)
    {
    TreeNode node
    = TreeNode.FromHandle(treeView, companyHandleDict[key]);
    if (node != null)
    {
    TreeNode tempNode
    = node.Nodes.Add(subKey, subKey, 0);
    if (!subCompanyHandleDict.ContainsKey(key + subKey))
    {
    subCompanyHandleDict.Add(key
    + subKey, tempNode.Handle);
    }
    }
    }
    }

      记录了这些TreeNode的Handle之后,我们如果要在这些节点上添加子节点的时候,就可以快速定位了。代码如下所示。

     foreach (Taxi taxi in taxiDcit.Values)
    {
    string key = taxi.MyInfo.Corporation + taxi.MyInfo.Filialy;
    TreeNode node
    = TreeNode.FromHandle(treeView, subCompanyHandleDict[key]);
    if (node != null)
    {
    TreeNode subNode
    = new TreeNode(taxi.MyBrand, 1, 2);
    subNode.Tag
    = "vehicle";
    node.Nodes.Add(subNode);
    }

      以上只是一个小技巧处理节点的定位,希望对大家有帮助。

  • 相关阅读:
    Jaxb2 实现JavaBean与xml互转
    标准输入与标准输出
    linux 一行一行的读取文件
    linux $* 和$@ if [ ](字符串比较)
    scala 学习(三)——Array和ArrayBuffer
    Shell编程(六)awk工具
    Shell编程(五)脚本语法
    Shell编程(四)Shell变量
    Shell编程(三)Shell特性
    Shell编程(一)概览
  • 原文地址:https://www.cnblogs.com/waw/p/2157084.html
Copyright © 2011-2022 走看看