Udostępnij za pośrednictwem


Instrukcje: dodawanie informacji niestandardowych do kontrolki TreeView lub ListView (Formularze systemu Windows)

Można utworzyć pochodny węzeł w kontrolce Windows Forms TreeView lub pochodny element w kontrolce ListView. Wyprowadzanie umożliwia dodawanie dowolnych pól, których potrzebujesz, a także niestandardowych metod i konstruktorów do ich obsługi. Jedną z tych funkcji jest dołączenie obiektu Klient do każdego węzła drzewa lub elementu listy. Poniżej przedstawiono przykłady dla kontrolki TreeView, ale takie samo podejście można użyć w przypadku kontrolki ListView.

Aby utworzyć węzeł drzewa

  • Utwórz nową klasę węzła pochodzącą z klasy TreeNode, która ma pole niestandardowe do rejestrowania ścieżki pliku.

    Class myTreeNode  
       Inherits TreeNode  
    
       Public FilePath As String  
    
       Sub New(ByVal fp As String)  
          MyBase.New()  
          FilePath = fp  
          Me.Text = fp.Substring(fp.LastIndexOf("\"))  
       End Sub  
    End Class  
    
    class myTreeNode : TreeNode  
    {  
       public string FilePath;  
    
       public myTreeNode(string fp)  
       {  
          FilePath = fp;  
          this.Text = fp.Substring(fp.LastIndexOf("\\"));  
       }  
    }  
    
    ref class myTreeNode : public TreeNode  
    {  
    public:  
       System::String ^ FilePath;  
    
       myTreeNode(System::String ^ fp)  
       {  
          FilePath = fp;  
          this->Text = fp->Substring(fp->LastIndexOf("\\"));  
       }  
    };  
    

Aby użyć węzła pochodnego drzewa

  1. Możesz użyć nowego węzła drzewa pochodnego jako parametru do wywołań funkcji.

    W poniższym przykładzie ścieżka ustawiona dla lokalizacji pliku tekstowego to folder Moje dokumenty. Dzieje się tak, ponieważ można założyć, że większość komputerów z systemem operacyjnym Windows będzie zawierać ten katalog. Dzięki temu użytkownicy z minimalnymi poziomami dostępu systemu mogą bezpiecznie uruchamiać aplikację.

    ' You should replace the bold text file
    ' in the sample below with a text file of your own choosing.  
    TreeView1.Nodes.Add(New myTreeNode (System.Environment.GetFolderPath _  
       (System.Environment.SpecialFolder.Personal) _  
       & "\ TextFile.txt ") )  
    
    // You should replace the bold text file
    // in the sample below with a text file of your own choosing.  
    // Note the escape character used (@) when specifying the path.  
    treeView1.Nodes.Add(new myTreeNode(System.Environment.GetFolderPath
       (System.Environment.SpecialFolder.Personal)
       + @"\TextFile.txt") );  
    
    // You should replace the bold text file
    // in the sample below with a text file of your own choosing.  
    treeView1->Nodes->Add(new myTreeNode(String::Concat(  
       System::Environment::GetFolderPath  
       (System::Environment::SpecialFolder::Personal),  
       "\\TextFile.txt")));  
    
  2. Jeśli otrzymasz węzeł drzewa i jest typu klasy TreeNode, należy rzutować na swoją klasę pochodną. Rzutowanie to jawna konwersja z jednego typu obiektu na inny. Aby uzyskać więcej informacji na temat rzutowania, zobacz niejawne i jawne konwersje (Visual Basic), rzutowanie i konwersję typów (Visual C#) lub operator rzutowania : () (Visual C++).

    Public Sub TreeView1_AfterSelect(ByVal sender As Object, ByVal e As System.Windows.Forms.TreeViewEventArgs) Handles TreeView1.AfterSelect  
       Dim mynode As myTreeNode  
       mynode = CType(e.node, myTreeNode)  
       MessageBox.Show("Node selected is " & mynode.filepath)  
    End Sub  
    
    protected void treeView1_AfterSelect (object sender,  
    System.Windows.Forms.TreeViewEventArgs e)  
    {  
       myTreeNode myNode = (myTreeNode)e.Node;  
       MessageBox.Show("Node selected is " + myNode.FilePath);  
    }  
    
    private:  
       System::Void treeView1_AfterSelect(System::Object ^  sender,  
          System::Windows::Forms::TreeViewEventArgs ^  e)  
       {  
          myTreeNode ^ myNode = safe_cast<myTreeNode^>(e->Node);  
          MessageBox::Show(String::Concat("Node selected is ",
             myNode->FilePath));  
       }  
    

Zobacz też