Erstellt ein Treeview-Control für die GUI.
GUICtrlCreateTreeView ( left, top [, width [, height [, style = -1 [, exStyle = -1]]]] )
left | Die linke Seite des Controls. Wird -1 verwendet, dann wird left mit Hilfe von GUICoordMode berechnet. |
top | Die Oberkante des Controls. Wird -1 verwendet, dann wird top mit Hilfe von GUICoordMode berechnet. |
width | [optional] Die Breite des Controls (voreingestellt ist die zuvor verwendete Breite). |
height | [optional] Die Höhe des Controls (voreingestellt ist die zuvor verwendete Höhe). |
style | [optional] Legt den Stil des Controls fest. Siehe Anhang GUI-Stile für Controls. Standard (-1) : $TVS_HASBUTTONS, $TVS_HASLINES, $TVS_LINESATROOT, $TVS_DISABLEDRAGDROP, $TVS_SHOWSELALWAYS Erzwungener Stil : $WS_TABSTOP |
exStyle | [optional] Legt den erweiterten Stil des Controls fest. Siehe Tabelle der erweiterten Stile. |
Erfolg: | Die Identifikationsnummer (Control-ID) des neuen Controls. |
Fehler: | 0. |
Um Informationen im Control zu setzen oder zu verändern siehe GUICtrlUpdate...() Funktionen.
Um weitere Stile zusätzlich zum Standardstil zu verwenden ist BitOR($GUI_SS_DEFAULT_TREEVIEW, newstyle, ... ) zu benutzen.
Um die oben festgelegten Wert verwenden zu können, muss man #include <TreeViewConstants.au3> in sein Skript schreiben
- - - - - - - - Erklärung der Controls - - - - - - - -
GUICoordMode (Option), GUICtrlCreateTreeViewItem, GUICtrlRead, GUICtrlUpdate..., GUIGetMsg
#include <GUIConstantsEx.au3>
#include <MsgBoxConstants.au3>
#include <StaticConstants.au3>
#include <TreeViewConstants.au3>
#include <WindowsConstants.au3>
Example()
Func Example()
GUICreate("Meine GUI mit Treeview", 350, 215)
Local $idTreeview = GUICtrlCreateTreeView(6, 6, 150, 150, BitOR($TVS_HASBUTTONS, $TVS_HASLINES, $TVS_LINESATROOT, $TVS_DISABLEDRAGDROP, $TVS_SHOWSELALWAYS), $WS_EX_CLIENTEDGE)
Local $idGeneralitem = GUICtrlCreateTreeViewItem("Allgemein", $idTreeview)
GUICtrlSetColor(-1, 0x0000C0)
Local $idDisplayitem = GUICtrlCreateTreeViewItem("Anzeige", $idTreeview)
GUICtrlSetColor(-1, 0x0000C0)
Local $idAboutitem = GUICtrlCreateTreeViewItem("Über", $idGeneralitem)
Local $idCompitem = GUICtrlCreateTreeViewItem("Computer", $idGeneralitem)
GUICtrlCreateTreeViewItem("Benutzer", $idGeneralitem)
GUICtrlCreateTreeViewItem("Auflösung", $idDisplayitem)
GUICtrlCreateTreeViewItem("Sonstiges", $idDisplayitem)
Local $idStartlabel = GUICtrlCreateLabel("Treeview Demo", 160, 90, 100, 20)
Local $idAboutlabel = GUICtrlCreateLabel("Dieses kleine Skript demonstriert die Benutzung eines Treeview Controls.", 160, 70, 150, 60)
GUICtrlSetState(-1, $GUI_HIDE) ; Versteckt den "aboutlabel"-Text während der Initialisierung
Local $idCompinfo = GUICtrlCreateLabel("Name:" & @TAB & @ComputerName & @CRLF & "OS:" & @TAB & @OSVersion & @CRLF & "SP:" & @TAB & @OSServicePack, 160, 30, 200, 80)
GUICtrlSetState(-1, $GUI_HIDE) ; Versteckt den "compinfo"-Text während der Initialisierung
GUICtrlCreateLabel("", 0, 170, 350, 2, $SS_SUNKEN)
Local $idTogglebutton = GUICtrlCreateButton("&Umschalten", 35, 185, 70, 20)
Local $idInfobutton = GUICtrlCreateButton("&Info", 105, 185, 70, 20)
Local $idStatebutton = GUICtrlCreateButton("Auf/Zu", 175, 185, 70, 20)
Local $idCancelbutton = GUICtrlCreateButton("&Abbrechen", 245, 185, 70, 20)
GUICtrlSetState($idGeneralitem, BitOR($GUI_EXPAND, $GUI_DEFBUTTON)) ; Expandiert den "Allgemein"-Tree und stellt ihn im Stil 'fett' dar
GUICtrlSetState($idDisplayitem, BitOR($GUI_EXPAND, $GUI_DEFBUTTON)) ; Expandiert den "Anzeige"-Tree und stellt ihn im Stil 'fett' dar
GUISetState(@SW_SHOW)
; Die Schleife wiederholt sich, bis der Benutzer die Beenden-Aktion der GUI auslöst.
While 1
$idMsg = GUIGetMsg()
Select
Case $idMsg = $idCancelbutton Or $idMsg = $GUI_EVENT_CLOSE
ExitLoop
Case $idMsg = $idTogglebutton ; Schriftstil 'Fett' ein/ausschalten
If BitAND(GUICtrlRead($idGeneralitem), $GUI_DEFBUTTON) Then
GUICtrlSetState($idGeneralitem, 0)
GUICtrlSetState($idDisplayitem, 0)
Else
GUICtrlSetState($idGeneralitem, $GUI_DEFBUTTON)
GUICtrlSetState($idDisplayitem, $GUI_DEFBUTTON)
EndIf
Case $idMsg = $idInfobutton
$idItem = GUICtrlRead($idTreeview) ; Holt die Control-ID des aktuell gewählten Treeview-Items
If $idItem = 0 Then
MsgBox($MB_SYSTEMMODAL, "Treeview Demo", "Momentan ist kein Eintrag markiert")
Else
$sText = GUICtrlRead($idItem, 1) ; Holt den Text des Treeview-Items
If $sText == "" Then
MsgBox($MB_SYSTEMMODAL, "Fehler", "Fehler während der Abfrage des Treeview-Items")
Else
MsgBox($MB_SYSTEMMODAL, "Treeview Demo", "Aktuell gewähltes Item ist: " & $sText) ; $advmsg[0] enthält den Text und $advmsg[1] den Statuswert des Treeview-Items
EndIf
EndIf
Case $idMsg = $idStatebutton ; Expandiert oder versteckt den markierten Tree
$idItem = GUICtrlRead($idTreeview)
If $idItem > 0 Then
$hItem = GUICtrlGetHandle($idItem)
GUICtrlSendMsg($idTreeview, $TVM_EXPAND, $TVE_TOGGLE, $hItem)
EndIf
; Die folgenden Items verstecken die anderen Labels (erster und zweiter Parameter) und zeigen anschließend die 'eigenen' Labels (dritter und vierter Parameter)
Case $idMsg = $idGeneralitem
GUIChangeItems($idAboutlabel, $idCompinfo, $idStartlabel, $idStartlabel)
Case $idMsg = $idAboutitem
GUICtrlSetState($idCompinfo, $GUI_HIDE)
GUIChangeItems($idStartlabel, $idStartlabel, $idAboutlabel, $idAboutlabel)
Case $idMsg = $idCompitem
GUIChangeItems($idStartlabel, $idAboutlabel, $idCompinfo, $idCompinfo)
EndSelect
WEnd
GUIDelete()
EndFunc ;==>Example
Func GUIChangeItems($idHidestart, $idHideend, $idShowstart, $idShowend)
Local $idx
For $idx = $idHidestart To $idHideend
GUICtrlSetState($idx, $GUI_HIDE)
Next
For $idx = $idShowstart To $idShowend
GUICtrlSetState($idx, $GUI_SHOW)
Next
EndFunc ;==>GUIChangeItems