FP_7SEGMENT

7セグメントデコーダ

このFP命令は、実行条件ENTRUEのとき、sで指定されたデータまたは定数を7セグメント表示用の4桁データに変換します。変換データは、dを先頭とするエリアに格納されます。7セグメント表示は、1桁を表すのに8ビット(1バイト)必要です。

パラメータ

入力

s (WORD)

データまたは定数

出力

d (DWORD)

変換データまたは定数

エラーフラグ

sys_bIsOperationErrorHold (TRUEになり、TRUEを保持)
  • インデックス修飾時にエリアを超えたとき

  • 結果が範囲外であるとき

sys_bIsOperationErrorNonHold (1回のスキャンに対してTRUE)
  • インデックス修飾時にエリアを超えたとき

  • 結果が範囲外であるとき

POUヘッダ

POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。 POUヘッダは全プログラム言語で使用できます。

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		wInput_value: WORD:=16#A731;
		wOutput_value: WORD:=0;
			(*result after 0->1 leading
edge from start:
16#77274F06*)
	END_VAR

POUボディ

変数bStartTRUEにセットされると、このファンクションが実行されます。

LDボディ

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_7SEGMENT!,,12,1,20,5,,?DEN?D@'s'?AENO?Cd);
B(B_CONTACT,,bStart,7,2,9,4,);
B(B_VARIN,,wInput_value,10,3,12,5,);
B(B_VAROUT,,wOutput_value,20,3,22,5,);
L(1,3,7,3);
L(9,3,12,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

STボディ

IF bStart then
    FP_7SEGMENT(s := wInput_value, d => wOutput_value);
END_IF;

最終修正日: 2019-08-01このページに関するフィードバックお問い合わせ窓口