JavaScript Editor
JavaScript Debugger|
| ||
You can create tree views in code as well as at design time. To see an example, take a look at the CreateTreeView program on the CD-ROM—this example creates a tree view of employees, each of whom has several sales account nodes.
The trick here is realizing that the hierarchical nature of tree views means that one node's Nodes collection can contain child nodes, which can itself contain child nodes, and so on, so you can refer to nodes using syntax like MyNode.Nodes(3). Nodes(5). To add a new node, you use the Nodes collection's Add method. Like other controls, you can use the BeginUpdate and EndUpdate methods to turn off updating of the tree view while you're updating it. Note that this example uses the Clear method to clear all nodes in the tree view before refilling it. (Note also that I'm using a few advanced programming techniques here, such as creating our own classes and storing objects in an ArrayList collection, which we'll see soon in the book.) Here's the code, showing how to stock a tree view with nodes, and how to give those nodes child nodes, and so on, at run time:
Public Class Form1
Inherits System.Windows.Forms.Form
'Windows Form Designer generated code
Private EmployeeArray As New ArrayList()
Private Sub Button1_Click(ByVal sender As System.Object, _
ByVal e As System.EventArgs) Handles Button1.Click
Dim intLoopIndex As Integer
For intLoopIndex = 0 To 9
EmployeeArray.Add(New Employee("Employee " & _
intLoopIndex.ToString()))
Next intLoopIndex
Dim EmployeeObject As Employee
For Each EmployeeObject In EmployeeArray
For intLoopIndex = 0 To 3
EmployeeObject.EmployeeAccounts.Add(New _
Account("Account " & intLoopIndex.ToString()))
Next intLoopIndex
Next EmployeeObject
TreeView1.BeginUpdate()
TreeView1.Nodes.Clear()
Dim RootNode = New TreeNode("Employees")
TreeView1.Nodes.Add(RootNode)
For Each EmployeeObject In EmployeeArray
TreeView1.Nodes(0).Nodes.Add(New _
TreeNode(EmployeeObject.EmployeeName))
Dim AccountObject As Account
For Each AccountObject In EmployeeObject.EmployeeAccounts
TreeView1.Nodes(0).Nodes(_
EmployeeArray.IndexOf(EmployeeObject)).Nodes.Add(_
New TreeNode(AccountObject.AccountID))
Next AccountObject
Next EmployeeObject
TreeView1.EndUpdate()
End Sub
End Class
Public Class Employee
Private Index = 0
Public EmployeeName As String
Public EmployeeAccounts As New ArrayList()
Public Sub New(ByVal Name As String)
EmployeeName = Name
End Sub
End Class
Public Class Account
Public AccountID As String
Public Sub New(ByVal ID As String)
AccountID = ID
End Sub
End Class
You can see the results in Figure 10.13; when you click the "Create tree view" button, the code creates the display you see in that figure.
|
| ||
Free JavaScript Editor
JavaScript Editor