移动位数据
如果触发器EN为TRUE,则此FP指令将把位数据从由s1_Start及s2_End指定的位数据区域移动至从d_Start指定的位数据区域开始的位数据块中。
输入
源位数据区域的起始地址
源位数据区域的结束地址
输出
目标位数据区域的起始地址
输入和输出变量必须为相同的数据类型。
操作数s1_Start和s2_End应该:
在相同的内存区,例如DT、WR、FL、LD...
s1_Start £ s2_End
如果s1_Start > s2_End
相应的F型指令:F5_BTM 位数据移动
在全局变量列表中,定义项目中所有POU都可以访问的变量。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
END_VAR
VAR_EXTERNAL
bStartAddress: BOOL:=FALSE;
bEndAddress: BOOL:=FALSE;
bTargetAddress: BOOL:=FALSE;
END_VAR
当变量bStart设置为TRUE时,执行此函数。 它将位X1~X8移动到目标区域YD~Y14。
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
B(B_F,FP_MOVE_BITS!,,13,1,22,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd_Start);
B(B_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,bStartAddress,11,3,13,5,);
B(B_VARIN,,bEndAddress,11,4,13,6,);
B(B_VAROUT,,bTargetAddress,22,3,24,5,);
L(1,3,6,3);
L(8,3,13,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
If (bStart) then
FP_MOVE_BITS(s1_Start := bStartAddress, s2_End := bEndAdress, d_Start => bTargetAddress);
End_if;