ItpWriteRParams
Der Baustein ItpWriteRParams schreibt R-Parameter in die NC.
![]() | Veraltete Version Dieser Funktionsbaustein existiert ausschließlich zur Gewährleistung der Kompatibilität mit bestehenden Projekten. Für neue Projekte verwenden Sie bitte den Baustein ItpWriteRParamsEx. |
VAR_INPUT
VAR_INPUT
bExecute : BOOL;
nChnId : UDINT;
pAddr : PVOID;
nIndex : DINT;
nCount : DINT;
tTimeOut : TIME;
END_VAR
bExecute: Mit einer steigenden Flanke wird der Schreibvorgang gestartet.
nChnId: ID des NC-Kanals dessen R-Parameter beschrieben werden sollen.
pAddr: Adresse der Variablen, die die zu schreibenden Daten enthält. Dabei werden die Daten direkt ab der angegebenen Adresse verwendet. D.h. nIndex ist nicht als Offset zu pAddr zu sehen. Die Daten befinden sich für gewöhnlich in einem Array vom Typ LREAL, das vom Anwender definiert werden muss.
nIndex: Beschreibt den Index des R-Parameters der aus NC Sicht beschrieben werden soll.
nCount: Anzahl der zu beschreibenden R-Parameter
tTimeOut: ADS Timeout-Delay
VAR_OUTPUT
VAR_OUTPUT
bBusy : BOOL;
bErr : BOOL;
nErrId : UDINT;
END_VAR
bBusy: Dieser Ausgang bleibt solange auf TRUE, bis der Baustein eine Befehlsanforderung ausführt, längstens aber für die Dauer der an dem 'Timeout'-Eingang angelegten Zeit. Während Busy = TRUE wird an den Eingängen kein neuer Befehl angenommen. Bitte beachten Sie, dass nicht die Ausführung des Dienstes, sondern nur dessen Annahme zeitlich überwacht wird.
bErr: Dieser Ausgang wird auf TRUE geschaltet, wenn bei der Ausführung eines Befehls ein Fehler aufgetreten ist. Der befehlsspezifische Fehlercode ist in 'nErrId' enthalten. Wird durch das Ausführen eines Befehls an den Eingängen auf FALSE zurückgesetzt.
nErrId: Enthält den befehlsspezifischen Fehlercode des zuletzt ausgeführten Befehls. Wird durch das Ausführen eines Befehls an den Eingängen auf 0 zurückgesetzt. Die Fehlernummern in ErrId können in der ADS Fehlerdokumentation oder in der NC Fehlerdokumentation (Fehlercodes ab 0x4000) nachgeschlagen werden.
Beispiel
In diesem Beispiel werden aus NC Sicht die Parameter R90 bis R99 beschrieben.
VAR
arrfRParam90to99 : ARRAY[0..9] OF LREAL;
fbWriteRParam : ItpWriteRParams;
n : INT := 0;
bWriteParam : BOOL := FALSE;
END_VAR
FOR n:=0 TO 9 DO
arrfRParam90to99[n] := 90 + n;
END_FOR
fbWriteRParam(
bExecute := bWriteParam,
nChnId := 2,
pAddr := ADR( arrfRParam90to99[0] ),
nIndex := 90,
nCount := 10,
tTimeOut := T#200ms );
Voraussetzungen
Entwicklungsumgebung | Zielplattform | Einzubindende SPS-Bibliotheken |
---|---|---|
TwinCAT V3.1.0 | PC oder CX (x86 oder x64) | Tc2_NCI |