返回带有32位偏移量的输入或输出的FL地址
此函数从输入/输出Offs中的值在输入/输出AdrFL的FL区域中生成32位地址。此输入/输出必须直接连接到基本函数的16位输入/输出。输入/输出Offs中的值代表FL数据区域内的地址偏移量。使用GetPointer32可以将其与内存区的数值一起传输到用户函数或功能块。
输入
得出16位FL偏移量地址
此引脚必须连接到允许数据类型为INT、WORD的基本函数的输入/输出
输出
地址FL0的32位偏移量
记住,通过将EN输入处变量的内存区值赋予函数Is_AreaFL,确定是否执行使用FL区域中创建的地址的基本函数。
此函数在内部访问其中一个也用于数组计算的索引寄存器。如果FL区域不可用于给定控制器,将自动生成地址DT0而不是FL地址。
函数Is_AreaFL始终返回FALSE,并阻止执行带有无意义地址的命令。因此,用户自定义函数及以此函数写入的功能块可在不支持FL区域的控制器上运行。
仅限LD和FBD编辑器:使用[指令]窗格中的[输入指令]或[输出指令]将所需指令插入编程窗口。
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*Activation of the function*)
DutNonBoolean: DUT_NonBoolean;
(*structured data type*)
diActualPosition: DINT:=0;
(*Beginning position from which data should be read from the IC card*)
END_VAR
这里声明了在上述DUT中分配的数据类型的变量DutNonBoolean。由于执行函数ReadFromIcCard之后,变量DutNonBoolean的值被覆盖,因此未执行对变量DutNonBoolean的元素赋予值。当变量bStart从FALSE变为TRUE时,执行函数ReadFromIcCard。此函数读取IC卡上以地址diActualPosition开头的值并将信息写入变量DutNonBoolean。请勿忘记必须通过菜单 正确格式化IC卡,而且如有必要,以地址diActualPosition开头的值应在IC卡上出现。
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 8 ;
NETWORK_BODY
B(B_CONTACT,,start,6,1,8,3,R);
B(B_F,ReadFromIcCard!,,18,1,27,8,,?DEN?DArea?DOffset?DSize?DPosition?AENO?C);
B(B_VARIN,,ActualPosition,16,6,18,8,);
B(B_VAROUT,,ActualPosition,27,3,29,5,);
B(B_VARIN,,Dut_NonBoolean,7,3,9,5,);
B(B_F,Size_Of_Var!,,9,5,16,7,,?D?C);
B(B_F,GetPointer!,,11,3,18,5,,?D?C);
B(B_VARIN,,2,16,4,18,6,);
L(18,2,18,3);
L(8,2,18,2);
L(1,2,6,2);
L(9,4,11,4);
L(9,4,9,6);
L(16,6,18,6);
L(1,0,1,8);
END_NETWORK_BODY
END_NET_WORK
END_BODY