Commander_COM Geschrieben 2. September 2002 Geschrieben 2. September 2002 Hallo, Ich möchte in einem Access2000 Formular mir Daten als große Übersicht in diesem Stil anzeigen lassen: +Anlage +Anlage |-+Gerät |-+Gerät |-+Komponente |-+Komponente |-+Komponente +Anlage +Anlage Lässt sich das irgendwie realisieren? Also in dem Stil, dass ich dann auf das Plus klicken kann und es mir die zur Anlage gehörigen Geräte und darunter dann die Komponenten anzeigt. Das beste wäre noch, dass wenn einer dieser Einträge in einer anderen Liste vermerkt ist, dass dieser dann farbig dargestellt wird. Hat irgendjemand eine Idee??? tHx4UrhLp Zitieren
Commander_COM Geschrieben 4. September 2002 Autor Geschrieben 4. September 2002 Weiß denn niemand Rat? :confused: Ich brauch das ganz dringend. Ich wäre auch für Vorschläge dankbar, die ähnlicher Natur sind, d.h. die Darstellung kann variieren, je nachdem was in Access 2000 möglich ist. Mir fällt nämlich nix gescheites weiter ein. An die Moderatoren: Sorry, wenn das als Threadpushing gelten sollte, ich machs auch nie wieder Gruß Zitieren
Commander_COM Geschrieben 4. September 2002 Autor Geschrieben 4. September 2002 Ich habs mir einfach gemacht und nun doch alles mit Listenfeldern dargestellt. Zitieren
tauron Geschrieben 9. September 2002 Geschrieben 9. September 2002 Moin ! weiss nicht ob Du es noch brauchst, aber es geht, ist nur ein bissel kompliziert. Dafür gibt es ein ActiveX-Steuerelement, das nennt sich "Microsoft Treeview Control Version 6.0". Du findest es im "Einfügen"-Menü unter "ActiveX-Steuerlement..". Das Problem an der Sache ist, das Du nicht einfach eine Datenquelle wie bei den anderen Steuerelementen angeben kannst, sondern das ganze über VBA füllen mußt. Also gibst Du dem Formular beim "Bei Laden"-Ereignis eine Ereignisprozedur, die das übernimmt. Der Aufbau um einen Knoten hinzuzufügen sieht folgendermaßen aus: (das Treeview-Element heisst tvw_Beispiel) tvw_Beispiel.Nodes.Add [<übergeordneter Knoten>], [<Verknüpfungsart>], <ID des Knoten>, <Text des Knoten> für den 1.Level sieht das also z.B. so aus: Set rst = dbs.OpenRecordset("Kunden") Do Until rst.EOF StrOrderKey = "k" & rst!Kundennr Me!tvw_Best.Nodes.Add , , StrOrderKey, rst!Name rst.MoveNext Loop er öffnet ein Recordset mit Kunden-Informationen ("Kundennr" und "Name") und geht ihn mit der Do Schleife komplett durch. Bei jedem Durchlauf erzeugt er einen Knoten. Da hier die Knoten für den 1.Level angelegt werden, wird der übergeordnete Knoten und die Verknüpfungsart weggelassen. "StrOrderKey" ist eine Variable, die die Kundennr mit einem vorangestelltem "k" enthält. Dies ist nötig, da er für die eindeutige Bezeichnung dieses Knoten keine reinen Zahlen akzeptiert. Weiter geht es mit dem 2.Level: Set rst = dbs.OpenRecordset("Bestellung") Do Until rst.EOF StrOrderKey = "b" & rst!Bestellungnr StrParentKey = "k" & rst!Kundennr Me!tvw_Best.Nodes.Add StrParentKey, tvwChild, StrOrderKey, rst!Datum rst.MoveNext Loop wieder wird ein Recordset geöffnet, diesmal mit allen Bestellungen ("Bestellungnr", "Kundennr" und "Datum") und wieder wird er komplett mit der Do Schleife durchlaufen. Da es sich um Knoten auf dem 2.Level handelt, muss für jeden eindeutig angegeben werden, zu welchem Level1 Knoten er gehört. Dies erfolgt über den String "StrParentKey", der wieder die Kundennr mit einem vorangestellten "k" enthält. Danach muss angegeben werden in welcher Beziehung die beiden stehen, "tvwChild" gibt an, das es sich um ein "Child", einen untergeordneten handelt. Danach wird wie in dem oberen Fall wieder eine eindeutige Bezeichnung durch den String StrOrderKey (Bestellungnr mit vorangestelltem "b") angegeben und schliesslich der angezeigte Wert, in diesem Fall das Bestelldatum. Das läßt sich so weiterbauen, Du musst halt darauf achten, das Du angibst, welchem Knoten der neue untergeordnet ist, und das jeder Knoten eine eindeutige Bezeichnung (die Buchstaben enthält, nur Zahlen gibt eine Fehlermeldung) erhält. Sorry für den langen (und späten) Post, aber ich hoffe es hilft Dir weiter ! gruß Christian Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.