FP_SD_GET_FREE_KBYTES

返回SD卡上的空闲千字节数

此FP指令以千字节计算SD卡上可用的空闲容量,并将结果存储在d_kBytes中。

参数

输出

d_kBytes (UDINT)

千字节数

标注

  • 也请参阅有关SD存储卡指令简介

  • 在SD存储卡指令的触发器EN变为TRUE后,SD存储访问活动标志(sys_bIsSDMemoryAccessActive)变为TRUE,并保持为TRUE直到执行完成。在此期间,无法执行其他SD存储卡指令。

  • 执行指令时,SD存储访问完成标志(sys_blsSDMemoryAccessDone)为FALSE,指令完成后变为TRUE并保持TRUE

错误标志

sys_bIsSDMemoryAccessError
  • FALSE:指令完成且没有错误时

  • TRUE:指令完成但有错误时

    使用sys_iSDMemoryAccessErrorCode评估错误代码。

示例

POU头

所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。

	VAR
		bStart: BOOL:=FALSE;
			(*activates the instrution*)
		udiFreeSdSpace: UDINT:=0;
	END_VAR

POU本体

当变量bStartFALSE变为TRUE时,执行此函数。它计算SD卡上的空闲千字节数,并将值存储在d_kBytes中。

LD本体

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 7 ;
        NETWORK_BODY
B(B_F,FP_SD_GET_FREE_KBYTES!,,18,0,31,4,,?DEN?AENO?Cd_kBytes);
B(B_VAROUT,,udiFreeSdSpace,31,2,33,4,);
B(B_CONTACT,,sys_bIsSDMemoryAccessActive,10,1,12,3,N);
B(B_CONTACT,,bStart,2,1,4,3,);
L(1,2,2,2);
L(4,2,10,2);
L(12,2,18,2);
L(1,0,1,7);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

IF bStart AND not sys_bIsSDMemoryAccessActive then
    FP_SD_GET_FREE_KBYTES(udiFreeSdSpace);
END_IF;

最后更新日期: 2024-03-07此页面上的反馈松下热线