FB_KinPresetRotation
The function block FB_KinPresetRotation sets the rotational state.
The rotational state is not persistent and must be reset after a TwinCAT restart or if a path is started after an ACS axis movement (direct mode).
Extended rotation range
|
VAR_INPUT
VAR_INPUT
bExecute : BOOL;
oidTrafo : UDINT;
stRotation : ARRAY[1..3] OF LREAL;
END_VAR
bExecute: The command is executed with a rising edge.
oidTrafo: Object ID (OTCID) of the kinematic transformation object.
stRotation: Presetting of MCS Rotation1, Rotation2 and Rotation3
VAR_OUTPUT
VAR_OUTPUT
bBusy : BOOL;
bDone : BOOL;
bError : BOOL;
nErrorId : UDINT;
END_VAR
bBusy: The output becomes TRUE when the command is started with bExecute and remains TRUE as long as the function block executes the command. While bBusy is TRUE, no new command is accepted at the inputs. If bBusy becomes FALSE again, the function block is ready for a new command. At the same time one of the outputs bDone or bError is set.
bDone: The output becomes TRUE when the command was executed successfully.
bError: The output bError is set to TRUE, if an error occurred during the command execution.
nErrorId: contains the command-specific error code of the most recently executed command. Details of the error code can be found in the ADS error documentation or in the NC error documentation (error codes from 0x4000).
Example: Equivalent rotations (same tool orientation)
Rotation1:= -180 Rotation1:= -180
Rotation2:= 45 Rotation2:= 45
Rotation3:= 157.95 Rotation3:= -202.05
FB_KinPresetRotation must be used before FB_KinConfigGroup or FB_KinCalcTrafo perform the forward transformation.
To use the extended rotation range with FB_KinCalcTrafo(bForward:=TRUE) without a kinematic group, the meta information uMetaInfo.aData[4] := 1 must be set. |
Requirements
Development environment | Target platform | PLC libraries to include |
---|---|---|
TwinCAT V3.1.4024.7 Advanced Motion Pack V3.1.10.1 | PC or CX (x86 or x64) | Tc2_KinematicTransformation (V3.2.7.3 or later) |