Schickt eine Nachricht an ein Control und bringt Informationen in lParam zurück.
GUICtrlRecvMsg ( controlID , msg [, wParam [, lParamType]] )
ControlID | Die Identifikationsnummer des Controls (Control-ID), wie von einer GUICtrlCreate... Funktion zurückgegeben, oder -1 für das zuletzt erzeugte Control. |
msg | Typ der Nachricht, die an das Control gesendet werden soll, wie in der Microsoft-Dokumentation zu Windows controls definiert. |
wParam | [optional] Eine Ganzzahl, der erste Parameter, der an ein Control geschickt wird. |
lParamType | [optional] Definiert den Typ von lParam, der von der Funktion zurückgegeben: 0 (Standard) für wParam und lParam, 1 für einen lParam String, 2 für eine lParam RECT Struktur. |
Erfolg: | Wert, der von der SendMessage Windows API zurückgegeben wurde (siehe Microsoft-Dokumentation). |
Fehler: | 0. |
Diese Funktion erlaubt es, spezielle Windows-Nachrichten (messages) über die SendMessage API von Windows direkt an ein Control zu schicken. Sie wird verwendet, um bestimmte Möglichkeiten von Controls zu nutzen, die über die einfachen GUICtrlRead() und GUICtrlUpdate...-Funktionen nicht erreichbar sind.
Wenn die Parameter wParam und lParamType nicht angegeben werden, wird ein Array aus zwei Items zurückgegeben (LPwParam, LPlParam).
Die RECT Struktur wird als Array aus 4 Items zurückgegeben (Left, Top, Right, Bottom) (übersetzt: links, oben, rechts, unten) .
- - - - - - - - Erklärung der Controls - - - - - - - -
GUICtrlSendMsg, GUICtrlUpdate...
#include <EditConstants.au3>
#include <GUIConstantsEx.au3>
#include <MsgBoxConstants.au3>
Example()
Func Example()
; Erstellt eine GUI mit einem Edit-Control.
Local $hGui = GUICreate("Beispiel")
Local $idEdit = GUICtrlCreateEdit("Zeile 0" & @CRLF, 0, 0, 400, 350)
Local $idButton_Ok = GUICtrlCreateButton("OK", 310, 370, 85, 25)
; Setzt Daten des Edit-Controls.
For $i = 1 To 25
GUICtrlSetData($idEdit, "Zeile " & $i & @CRLF, 1)
Next
; Setzt den Fokus auf das Edit-Control.
GUICtrlSetState($idEdit, $GUI_FOCUS)
; Zeigt die GUI
GUISetState(@SW_SHOW, $hGui)
; Initialisiert die Variable $aCtrlRecvMsg für das speichern des Wertes der von GUICtrlRecvMsg zurückgegeben wurde.
Local $aCtrlRecvMsg = 0
; Die Schleife wiederholt sich, bis der Benutzer die Beenden-Aktion der GUI auslöst.
While 1
Switch GUIGetMsg()
Case $GUI_EVENT_CLOSE
ExitLoop
Case $idButton_Ok
; Sendet die Nachricht EM_GETSEL um die aktuelle Markierung des Edit-Control zu empfangen.
$aCtrlRecvMsg = GUICtrlRecvMsg($idEdit, $EM_GETSEL)
; Setzt den Fokus auf das Edit-Control.
GUICtrlSetState($idEdit, $GUI_FOCUS)
; Falls GUICtrlRecvMsg 0 zurückgibt, so kommt ein Fehler. Sonst wird der Inhalt des Arrays angezeigt.
If $aCtrlRecvMsg = 0 Then
MsgBox($MB_SYSTEMMODAL, "", "Ein Fehler ist aufgetreten Der zurückgegebene Wert lautet - " & $aCtrlRecvMsg)
Else
MsgBox($MB_SYSTEMMODAL, "", "Start: " & $aCtrlRecvMsg[0] & " Ende: " & $aCtrlRecvMsg[1])
EndIf
EndSwitch
WEnd
; Löscht die vorherige GUI und alle Controls.
GUIDelete($hGui)
EndFunc ;==>Example