Foros del Web » Programación para mayores de 30 ;) » Programación General »

Tabla de contenido + Treeview

Estas en el tema de Tabla de contenido + Treeview en el foro de Programación General en Foros del Web. Hola a todos. Deseo hacer una especie de tabla de contenido en un treeview bajo VBA6. Si alguien tiene alguna idea le agradeceria No se ...
  #1 (permalink)  
Antiguo 25/06/2012, 08:22
 
Fecha de Ingreso: junio-2012
Mensajes: 4
Antigüedad: 12 años, 7 meses
Puntos: 0
Tabla de contenido + Treeview

Hola a todos. Deseo hacer una especie de tabla de contenido en un treeview bajo VBA6. Si alguien tiene alguna idea le agradeceria

No se conocen los titulos y no se sabe cuantos niveles habra

1 Hola
1.1 que mas
1.1.1 que tak

2. a2
2.1 a21
2.2 a22
2.3 a23

3 tema3
3.1 tema31
3.2 tema32
3.2.1 tema321
3.2.2 tema322
3.2.3 tema323


Tengo el siguiente codigo pero me ha estado borrando o anexando nivelacion incorrecta o me borra la que ya se introdujo o anexa la nueva a la vieja (ejemplo 2 1.1 A1)

Codigo:


Sub OrderNodesv3(tv As MSComctlLib.TreeView, prefix As String, _
separator As String, _
NodNode As MSComctlLib.Node)
'Dim NodNode As MSComctlLib.Node
Dim Brothers As Long
Dim NodParentsNode As MSComctlLib.Node
Dim straux As String, straux2 As String, Auxarr() As String, TypeAddNew As String
Dim i As Integer
10 Brothers = 1

20 Set NodParentsNode = NodNode
30 If Not NodParentsNode Is Nothing Then
'ir al primer hermano
40 Set NodParentsNode = GotoFirstBrother(tv, NodNode)
'contar el número de hermanos incluyendo al nodo como miembro de la familia
50 Do Until NodParentsNode.Next Is Nothing
60 Brothers = Brothers + 1
70 Set NodParentsNode = NodParentsNode.Next
80 Loop
'
'Set NodParentsNode = GotoFirstBrother(tv)
90 TypeAddNew = PDTActividad.Relacion.Value
Select Case TypeAddNew
Case "Hijo"
Set NodParentsNode = tv.SelectedItem
100 i = 1
110 Do
'If InStr(1, Trim(NodParentsNode.text), PDTActividad.Prefijo & separator, vbTextCompare) = 1 Then
120 If InStr(1, Trim(NodParentsNode.text), PDT.tvTreeView.Tag & separator, vbTextCompare) = 1 Then '06/20
130 NodParentsNode.text = Trim(Mid(NodParentsNode.text, InStr(1, NodParentsNode.text, " ", vbTextCompare), Len(NodParentsNode.text)))
140 End If
150
'straux2 = Mid(NodParentsNode.text, 1, InStr(1, NodParentsNode.text, ".", vbTextCompare) - 1)


straux = "°" & prefix & separator & Right(String(Len(CStr(Brothers)), "0") & i, Len(CStr(Brothers))) & separator ' 06/20
160 NodParentsNode.text = Trim(straux) & " " & Trim(NodParentsNode.text)

170 If Not NodParentsNode.Child Is Nothing Then
Call OrderNodesv3(tv, straux, ".", NodParentsNode.Child)
End If
190 i = i + 1
210 Set NodParentsNode = NodParentsNode.Next
220 Loop Until NodParentsNode Is Nothing

Case "Raíz"
Set NodParentsNode = tv.SelectedItem
i = 1
Do

If InStr(1, Trim(NodParentsNode.text), PDT.tvTreeView.Tag & separator, vbTextCompare) = 1 Then '06/20
NodParentsNode.text = Trim(Mid(NodParentsNode.text, InStr(1, NodParentsNode.text, " ", vbTextCompare), Len(NodParentsNode.text)))
End If

straux = prefix
NodParentsNode.text = Trim(straux) & " " & Trim(NodParentsNode.text)

If Not NodParentsNode.Child Is Nothing Then
Call OrderNodesv3(tv, straux, ".", NodParentsNode.Child)
End If
i = i + 1
Set NodParentsNode = NodParentsNode.Next
Loop Until NodParentsNode Is Nothing
End Select
230 End If
End Sub

Etiquetas: contenido, tabla, treeview
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 06:32.