Schickt eine Nachricht an ein Control und bringt Informationen in lParam zurück.
GUICtrlRecvMsg ( controlID , msg [, wParam [, lParamType]] )
Parameter
| ControlID | Die Identifikationsnummer des Controls (Control-ID), wie von einer GUICtrlCreate... Funktion zurückgegeben. |
| 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. |
Rückgabewert
| Erfolg: | Gibt den Wert zurück, der von der SendMessage Windows API zurückgegeben wurde (siehe Microsoft-Dokumentation). |
| Fehler: | Gibt 0 zurück. |
Bemerkungen
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.
Verwandte Funktionen
GUICtrlSendMsg, GUICtrlUpdate...
Beispiel
#include <GUIConstantsEx.au3>
#include <EditConstants.au3>
GUICreate("Meine GUI") ; Erstellt ein GUI-Fenster welches mittig ausgerichtet wird
$nEdit = GUICtrlCreateEdit ("Zeile 0", 10,10)
GUICtrlCreateButton ("Ok", 20,200,50)
GUISetState ()
For $n=1 To 5
GUICtrlSetData ($nEdit, @CRLF & "Zeile "& $n)
Next
; Die Schleife wiederholt sich, bis der Benutzer die Beenden-Aktion der GUI auslöst
Do
$msg = GUIGetMsg()
If $msg >0 Then
$a=GUICtrlRecvMsg($nEdit, $EM_GETSEL)
GUICtrlSetState($nEdit,$GUI_FOCUS) ; Setzt Fokus zurück auf Edit-Control
; Zeigt den wParam und den lParam Wert an, der von dem Control zurückgegeben wird
MsgBox(0,"Aktuelle Auswahl",StringFormat("Start=%d Ende=%d", $a[0], $a[1]))
EndIf
Until $msg = $GUI_EVENT_CLOSE