Copiar datos a un bloque de memoria
Estas instrucciones FP copian los datos o la constante equivalente especificados por s al bloque de memoria especificado por d1_Start y d2_End si la entrada de trigger EN es TRUE.
Entrada
Valor fuente a copiar
Salida
Dirección de inicio del área de datos de destino.
Dirección final del área de datos de destino.
Las variables de entrada y salida tiene que ser del mismo tipo de datos.
Las áreas d1_Start y d2_End deben cumplir:
en la misma área de memoria, p. ej., DT, WR, FL, LD ...
d1_Start £ d2_End
si el área especificada utilizando el modificador índice supera el límite.
si d1_Start > d2_End
Instrucciones F correspondientes: F11_COPY
Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
aiDataField: ARRAY [0..6] OF INT:=[1,3,5,7,9,11,13];
(*result after a 0->1 leading
edge from start:
[1,3,5,11,11,11,13]*)
END_VAR
Cuando la variable bStart se encuentra a TRUE, se ejecuta la función.
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_COPY!,,11,1,18,6,,?DEN?D@'s'?AENO?Cd1_Start?Cd2_End);
B(B_CONTACT,,bStart,3,2,5,4,);
B(B_VARIN,,11,9,3,11,5,);
B(B_VAROUT,,aiDataField[3],18,3,20,5,);
B(B_VAROUT,,aiDataField[5],18,4,20,6,);
L(1,3,3,3);
L(5,3,11,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF bStart then
(* Copy the value 11 to aiDataField[3], *)
(* aiDataField[4] and aiDataField[5] *)
FP_COPY(s := 11, d1_Start => aiDataField[3], d2_End => aiDataField[5]);
END_IF;