FP_HEX_TO_ASCII

HEX -> ASCII-Umwandlung

Dieser FP-Befehl wandelt die hexadezimalen Werte am Eingang s_Start in ASCII-Code um, wenn der Trigger EN auf TRUE gesetzt ist. n_Bytes legt die Anzahl der umzuwandelnden Bytes fest. Das Ergebnis wird in den Speicherbereich d_Start geschrieben. Im ASCII-Code werden für die Darstellung eines hexadezimalen Zeichens 8 Bit (1 Byte) benötigt. Nach der ASCII-Umwandlung ist der Zieldatenbereich daher doppelt so groß wie der Quelldatenbereich.

Parameter

Eingang

s_Start (WORD, DWORD)

Hexadezimale Werte

n_Bytes (INT, DINT, UINT, UDINT)

Anzahl der Bytes

Ausgang

d_Start (WORD, INT, UINT)

Anfangsadresse des Datenbereichs für die Ergebnisse. Die Größe beträgt n_Bits * 2 Worte.

Anmerkungen

Die beiden Zeichen, die ein Byte darstellen, werden bei der Speicherung vertauscht. Zwei Bytes werden als ein Datensegment umgewandelt.

Fehleralarmmerker

sys_bIsOperationErrorHold (wird auf TRUE gesetzt und bleibt TRUE)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn die durch n_Bytes festgelegte Bytezahl den in s_Start festgelegten Speicherplatz überschreitet

  • wenn berechneten Ergebnisse den in d_Start festgelegten Speicherplatz überschreiten

  • wenn n_Bytes= 0 oder ein negativer Wert ist

sys_bIsOperationErrorNonHold (wird für einen Zyklus auf TRUE gesetzt)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn die durch n_Bytes festgelegte Bytezahl den in s_Start festgelegten Speicherplatz überschreitet

  • wenn berechneten Ergebnisse den in d_Start festgelegten Speicherplatz überschreiten

  • wenn n_Bytes= 0 oder ein negativer Wert ist

Beispiel16-Bit-Daten

Offset

Hex. Zeichen

Offset

Umgewandelter ASCII-Code

Zeichenfolgenäquivalent

s_Start

0

16#ABCD

Þ

d_Start

0

16#4443

DC

n_Bytes

16#0002

16#4241

BA

Beispiel32-Bit-Daten

Offset

Hex. Zeichen

Offset

Umgewandelter ASCII-Code

Zeichenfolgenäquivalent

s_Start

0

16#1234

Þ

d_Start

0

16#3433

43

1

16#5678

1

16#3231

21

n_Bytes

16#0004

16#3837

87

16#3635

65

Beispiel

POE-Kopf

Im POE-Kopf werden alle Ein- und Ausgangsvariablen deklariert, die für die Programmierung dieser Funktion verwendet werden.Für alle Programmiersprachen wird der gleiche POE-Kopf verwendet.

	VAR
		bStart: BOOL:=FALSE;
		awInput: ARRAY [0..2] OF WORD:=[16#ABCD,2(0)];
		awResult: ARRAY [0..5] OF WORD:=[6(16#FFFF)];
	END_VAR

POE-Rumpf

Wenn die Variable bStart auf TRUE gesetzt wird, wird die Funktion ausgeführt.

KOP-Rumpf

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 9 ;
        NETWORK_BODY
B(B_COMMENT,,After conversion: ø^awResult[0]=16#4443ø^awResult[1]=16#4241ø^awResult[2]=16#3030ø^awResult[3]=16#3030ø^awResult[4] is not written,23,0,38,6,);
B(B_CONTACT,,bStart,4,5,6,7,R);
B(B_F,FP_HEX_TO_ASCII!,,12,4,22,9,,?DEN?D@'s'?Dn_Chars?AENO?Cd_Start);
B(B_VARIN,,awInput[0],10,6,12,8,);
B(B_VAROUT,,awResult[0],22,6,24,8,);
B(B_VARIN,,4,10,7,12,9,);
L(1,0,1,9);
L(1,6,4,6);
L(6,6,12,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST-Rumpf

if (DF(bStart)) then
	FP_HEX_TO_ASCII(s_Start := awInput[0], n_Bytes := 4, d_Start => awResult[0]);
	(* After conversion: 
		awResult[0]=16#4443
		awResult[1]=16#4241
		awResult[2]=16#3030
		awResult[3]=16#3030
		awResult[4] is not written *)
end_if;

Letzte Änderung: 2024-11-21Feedback zu dieser SeitePanasonic Hotline