Main.st 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032
  1. PROGRAM _INIT
  2. RTInfo_0(enable:=1);
  3. Wartezeit_OPCUA := 1100;
  4. END_PROGRAM
  5. PROGRAM _CYCLIC
  6. //********************************** Tisch 1 ***********************************************
  7. (* Lesen *)
  8. gMerker_Tisch_1_RFID_Vorhanden := gTisch_1_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *) //Cech-Comment: Wenn dieses Bit gesetzt ist, dann ist ein Datenträger im LEsebereich
  9. //Cech-Comment: Diese zehn Integer-Werte sind im Balluff-Manual MAN_BIS_M_4XX_045_... Kap.9.2 S48 beschrieben
  10. // Die TAG-UID wird automatisch nach einem TAG-PResent vom Lesekopf ausgelesen und in das LEseregister geschrieben; da braucht kein LEsebefehl ausgegeben werden
  11. IF gMerker_Tisch_1_Auftrag_Lesen = TRUE THEN
  12. // gMerker_Lesen_Fertig := FALSE;
  13. gTisch_1_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  14. gTisch_1_RFID_Write[2] := 0;
  15. gTisch_1_RFID_Write[3] := 0;
  16. gTisch_1_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  17. gTisch_1_RFID_Write[5] := 0;
  18. gTisch_1_RFID_Write[6] := 0;
  19. gTisch_1_RFID_Write[7] := 0;
  20. gTisch_1_RFID_Write[8] := 0;
  21. gTisch_1_RFID_Write[9] := 1;
  22. gTisch_1_RFID_Write[0].0 := TRUE; (*Cech: Bit0: nuer Auftrag an Reader, Bit2:Reset, Bit5:Kopfabschaltung, Bit6: Toggeln für längere Abfragen/Aufträge, wenn SPS bereit ist, weitere Daten zu übernehmen*)
  23. END_IF
  24. (* Schreiben *)
  25. (* Befehlsdaten *)
  26. IF gMerker_neuen_Befehl_schreiben = TRUE THEN
  27. gTisch_1_RFID_Write[1] := 2; (* Datenträger beschreiben *)
  28. gTisch_1_RFID_Write[2] := 0; (* Daten *)
  29. gTisch_1_RFID_Write[3] := 0; (* Daten *)
  30. gTisch_1_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  31. gTisch_1_RFID_Write[5] := 0; (* Daten *)
  32. gTisch_1_RFID_Write[6] := 0; (* Daten *)
  33. gTisch_1_RFID_Write[7] := 0; (* Daten *)
  34. gTisch_1_RFID_Write[8] := 0; (* Daten *)
  35. gTisch_1_RFID_Write[0].0 := TRUE; (* neuer Auftrag steht an *)
  36. END_IF
  37. (* Write Variable nullen *)
  38. IF gMerker_Tisch_1_alles_nullen = TRUE THEN
  39. gTisch_1_RFID_Write[1] := 0;
  40. gTisch_1_RFID_Write[2] := 0;
  41. gTisch_1_RFID_Write[3] := 0;
  42. gTisch_1_RFID_Write[4] := 0;
  43. gTisch_1_RFID_Write[5] := 0;
  44. gTisch_1_RFID_Write[6] := 0;
  45. gTisch_1_RFID_Write[7] := 0;
  46. gTisch_1_RFID_Write[8] := 0;
  47. gTisch_1_RFID_Write[0] := 0;
  48. END_IF
  49. gTisch_1_RFID_Write[9] := gTisch_1_RFID_Write[0];
  50. CASE Tisch_1_RFID OF
  51. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  52. 0: IF gTisch_1_RFID_Read[0] = 129 AND gTisch_1_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde, dann liefert der TAG automatisch die UID zurück
  53. gMerker_Debug_Test_Counter_RFID := 00; //Cech-Comment: eingefügt für TEstzwecke
  54. // gMerker_Tisch_1_RFID_UID[0] := gTisch_1_RFID_Read[1];
  55. // gMerker_Tisch_1_RFID_UID[1] := gTisch_1_RFID_Read[2];
  56. // gMerker_Tisch_1_RFID_UID[2] := gTisch_1_RFID_Read[3];
  57. // gMerker_Tisch_1_RFID_UID[3] := gTisch_1_RFID_Read[4];
  58. // gMerker_Tisch_1_RFID_UID[4] := gTisch_1_RFID_Read[5];
  59. // gMerker_Tisch_1_RFID_UID[5] := gTisch_1_RFID_Read[6];
  60. // gMerker_Tisch_1_RFID_UID[6] := gTisch_1_RFID_Read[7];
  61. // gMerker_Tisch_1_RFID_UID[7] := gTisch_1_RFID_Read[8];
  62. // gMerker_Tisch_1_RFID_UID_STRARR[0] := USINT_TO_STRING (gTisch_1_RFID_Read[1]);
  63. // gMerker_Tisch_1_RFID_UID_STRARR[1] := USINT_TO_STRING (gTisch_1_RFID_Read[2]);
  64. // gMerker_Tisch_1_RFID_UID_STRARR[2] := USINT_TO_STRING (gTisch_1_RFID_Read[3]);
  65. // gMerker_Tisch_1_RFID_UID_STRARR[3] := USINT_TO_STRING (gTisch_1_RFID_Read[4]);
  66. // gMerker_Tisch_1_RFID_UID_STRARR[4] := USINT_TO_STRING (gTisch_1_RFID_Read[5]);
  67. // gMerker_Tisch_1_RFID_UID_STRARR[5] := USINT_TO_STRING (gTisch_1_RFID_Read[6]);
  68. // gMerker_Tisch_1_RFID_UID_STRARR[6] := USINT_TO_STRING (gTisch_1_RFID_Read[7]);
  69. // gMerker_Tisch_1_RFID_UID_STRARR[7] := USINT_TO_STRING (gTisch_1_RFID_Read[8]);
  70. gMerker_Tisch_1_STRING_HELPER := '';
  71. gMerker_Tisch_1_RFID_UID_STR := '';
  72. FOR i := 1 TO 8 DO
  73. gMerker_Tisch_1_STRING_HELPER := USINT_TO_STRING (gTisch_1_RFID_Read[i]);
  74. IF LEN(gMerker_Tisch_1_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  75. gMerker_Tisch_1_STRING_HELPER := CONCAT('00', gMerker_Tisch_1_STRING_HELPER);
  76. ELSIF LEN(gMerker_Tisch_1_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  77. gMerker_Tisch_1_STRING_HELPER := CONCAT('0', gMerker_Tisch_1_STRING_HELPER);
  78. END_IF;
  79. gMerker_Tisch_1_RFID_UID_STR := CONCAT( gMerker_Tisch_1_RFID_UID_STR, gMerker_Tisch_1_STRING_HELPER );
  80. END_FOR
  81. Tisch_1_RFID := 5;
  82. END_IF
  83. //Cech-Implement-Ende
  84. 5: IF gMerker_Tisch_1_RFID_Vorhanden = TRUE AND gMerker_Tisch_1_RFID_Reset = FALSE (*AND gMerker_Tisch_1_lesen_fertig = FALSE*) THEN
  85. gMerker_Debug_Test_Counter_RFID := 05; //Cech-Comment: eingefügt für TEstzwecke
  86. gMerker_Tisch_1_Auftrag_Lesen := TRUE;
  87. Tisch_1_RFID := 10;
  88. END_IF
  89. 10: lWarten_RFID_Fehler_Tisch_1 := lWarten_RFID_Fehler_Tisch_1 + (RTInfo_0.cycle_time/1000);
  90. IF gTisch_1_RFID_Read[0] = 135 THEN //135 : 1000 0111 / Cech-Comment: Bit: 0...Tag im Lesebereich, 1...Auftragsbearbeitung läuft, 2...Auftrag fehlerlos beendet, 3...Auftrag fehlerhaft bearbeitet, 5...Wenn toggelt: Sensor bereit, weitere Daten zu übermitteln, 6...Sensor abgeschaltet, 7...Sensor bereit
  91. gMerker_Debug_Test_Counter_RFID := 10; //Cech-Comment: eingefügt für TEstzwecke
  92. gMerker_RFID_Value_Tisch_1 := gTisch_1_RFID_Read[1];
  93. // gMerker_RFID_Tisch_1_gelesen := TRUE;
  94. // gMerker_Tisch_1_lesen_fertig := TRUE;
  95. lWarten_RFID_Fehler_Tisch_1 := 0;
  96. Tisch_1_RFID := 15;
  97. ELSIF lWarten_RFID_Fehler_Tisch_1 >= 5000 AND gTisch_1_RFID_Read[0] <> 135 THEN //Wenn nach 5s noch keine fehlerfreie Rückmeldung vom LEser gekommen ist, dann wird der Leser resetiert und alles wieder rückgesetzt ab 100:
  98. gMerker_Debug_Test_Counter_RFID := 11; //Cech-Comment: eingefügt für TEstzwecke
  99. gMerker_Tisch_1_Auftrag_Lesen := FALSE;
  100. gMerker_Tisch_1_RFID_Reset := TRUE;
  101. lWarten_RFID_Fehler_Tisch_1 := 0;
  102. Tisch_1_RFID := 100;
  103. END_IF
  104. 15:
  105. IF gMerker_RFID_Value_Tisch_1 <> 0 THEN //ungleich 0 von gTisch_1_RFID_Read[1] bedeutet einen Fehlercode; ohne Fehler muss das 00h sein
  106. gMerker_Debug_Test_Counter_RFID := 15; //Cech-Comment: eingefügt für TEstzwecke
  107. gMerker_RFID_Tisch_1_gelesen := TRUE;
  108. gMerker_Tisch_1_lesen_fertig := TRUE;
  109. Tisch_1_RFID := 20;
  110. ELSIF gMerker_RFID_Value_Tisch_1 = 0 THEN //kein Fehler beim Lesen
  111. gMerker_Debug_Test_Counter_RFID := 16; //Cech-Comment: eingefügt für TEstzwecke
  112. gMerker_RFID_Tisch_1_gelesen := FALSE;
  113. gMerker_Tisch_1_lesen_fertig := FALSE;
  114. Tisch_1_RFID := 100;
  115. END_IF
  116. 20: lWarten_fuer_OPCUA_Tisch_1 := lWarten_fuer_OPCUA_Tisch_1 + (RTInfo_0.cycle_time/1000);
  117. IF gMerker_Tisch_1_RFID_Vorhanden = FALSE AND gTisch_1.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_1 >= Wartezeit_OPCUA THEN
  118. gMerker_Debug_Test_Counter_RFID := 20; //Cech-Comment: eingefügt für TEstzwecke
  119. gMerker_Tisch_1_Auftrag_Lesen := FALSE;
  120. gMerker_RFID_Value_Tisch_1 := 0;
  121. gTisch_1_RFID_Write[0] := 4; //SW-Reset des RFID-Sensors
  122. gMerker_Tisch_1_RFID_UID_STR := '0';
  123. Tisch_1_RFID := 30;
  124. END_IF
  125. 30:
  126. IF gTisch_1_RFID_Read[0] = 0 THEN
  127. gMerker_Debug_Test_Counter_RFID := 30; //Cech-Comment: eingefügt für TEstzwecke
  128. gTisch_1_RFID_Write[0] := 0;
  129. Tisch_1_RFID := 0;
  130. END_IF
  131. 100: //Hier geht es weiter, wenn die Daten fehlerfrei empfangen wurden
  132. IF gMerker_Tisch_1_Auftrag_Lesen = FALSE AND gMerker_Tisch_1_RFID_Reset = TRUE THEN
  133. gMerker_Debug_Test_Counter_RFID := 100; //Cech-Comment: eingefügt für TEstzwecke
  134. gTisch_1_RFID_Write[0] := 4; //SW-Reset des RFID-Sensors
  135. gMerker_RFID_Value_Tisch_1 := 0;
  136. gMerker_Tisch_1_RFID_UID_STR := '0';
  137. Tisch_1_RFID := 110;
  138. END_IF
  139. 110:
  140. IF gTisch_1_RFID_Read[0] = 0 THEN
  141. gMerker_Debug_Test_Counter_RFID := 110; //Cech-Comment: eingefügt für TEstzwecke
  142. gMerker_Tisch_1_alles_nullen := TRUE;
  143. Tisch_1_RFID := 120;
  144. END_IF
  145. 120:
  146. IF gTisch_1_RFID_Write[0] = 0 AND gTisch_1_RFID_Write[1] = 0 AND gTisch_1_RFID_Write[2] = 0 AND gTisch_1_RFID_Write[3] = 0 AND gTisch_1_RFID_Write[4] = 0 AND gTisch_1_RFID_Write[5] = 0 AND gTisch_1_RFID_Write[6] = 0 AND gTisch_1_RFID_Write[7] = 0 AND gTisch_1_RFID_Write[8] = 0 AND gTisch_1_RFID_Write[9] = 0 THEN
  147. gMerker_Debug_Test_Counter_RFID := 120; //Cech-Comment: eingefügt für TEstzwecke
  148. gMerker_Tisch_1_alles_nullen := FALSE;
  149. gMerker_Tisch_1_RFID_Reset := FALSE;
  150. Tisch_1_RFID := 0;
  151. END_IF
  152. END_CASE
  153. // SCHREIBEN AUF ALLE GLEICH
  154. CASE RFID_Schreiben OF
  155. 0:
  156. IF gMerker_Tisch_1_RFID_Vorhanden = TRUE AND gMerker_OPCUA_Schreibauftrag = TRUE AND gMerker_Tisch_1_lesen_fertig = TRUE THEN
  157. gTisch_1_RFID_Write[0] := 4; // Kopf-Reset
  158. RFID_Schreiben := 10;
  159. END_IF
  160. 10:
  161. IF gTisch_1_RFID_Read[0] = 0 THEN
  162. gMerker_Tisch_1_alles_nullen := TRUE;
  163. RFID_Schreiben := 20;
  164. END_IF
  165. 20:
  166. IF gTisch_1_RFID_Write[0] = 0 AND gTisch_1_RFID_Write[1] = 0 AND gTisch_1_RFID_Write[2] = 0 AND gTisch_1_RFID_Write[3] = 0 AND gTisch_1_RFID_Write[4] = 0 AND gTisch_1_RFID_Write[5] = 0 AND gTisch_1_RFID_Write[6] = 0 AND gTisch_1_RFID_Write[7] = 0 AND gTisch_1_RFID_Write[8] = 0 AND gTisch_1_RFID_Write[9] = 0 THEN
  167. gMerker_Tisch_1_alles_nullen := FALSE;
  168. gMerker_neuen_Befehl_schreiben := TRUE;
  169. RFID_Schreiben := 30;
  170. END_IF
  171. 30:
  172. IF gTisch_1_RFID_Read[0] = 163 THEN //163 : 10100011 betriebsbereit; toggelbit zeigt an dass Kopf bereit weitere Daten zu übermitteln; Auftrag erkannt und entgegengenommen; Datenträger im Lesebereich;
  173. gMerker_neuen_Befehl_schreiben := FALSE;
  174. gMerker_Tisch_1_alles_nullen := TRUE;
  175. RFID_Schreiben := 40;
  176. END_IF
  177. 40:
  178. IF gTisch_1_RFID_Write[0] = 0 AND gTisch_1_RFID_Write[1] = 0 AND gTisch_1_RFID_Write[2] = 0 AND gTisch_1_RFID_Write[3] = 0 AND gTisch_1_RFID_Write[4] = 0 AND gTisch_1_RFID_Write[5] = 0 AND gTisch_1_RFID_Write[6] = 0 AND gTisch_1_RFID_Write[7] = 0 AND gTisch_1_RFID_Write[8] = 0 AND gTisch_1_RFID_Write[9] = 0 THEN
  179. gMerker_Tisch_1_alles_nullen := FALSE;
  180. gTisch_1_RFID_Write[1] := gMerker_OPCUA_Seriennummer_Test;
  181. gTisch_1_RFID_Write[2] := 0;
  182. gTisch_1_RFID_Write[3] := 0;
  183. gTisch_1_RFID_Write[4] := 0;
  184. gTisch_1_RFID_Write[5] := 0;
  185. gTisch_1_RFID_Write[6] := 0;
  186. gTisch_1_RFID_Write[7] := 0;
  187. gTisch_1_RFID_Write[8] := 0;
  188. gTisch_1_RFID_Write[0] := 65; //65: 0100 0001 das obere Bit zeigt an, durch Toggelung, dass die Linien-SPS bereit ist, Daten vom Kopf zu empfangen
  189. RFID_Schreiben := 50;
  190. END_IF
  191. 50:
  192. IF gTisch_1_RFID_Read[0] = 167 THEN //167 1010 0111, Kopf bereit;Kopf bereit für neue Daten; Auftrag ohne Fehler beendet; Auftrag erkannt und entgegengenommen; Datenträger im LEsebereich des Kopfes
  193. gMerker_Tisch_1_alles_nullen := TRUE;
  194. RFID_Schreiben := 60;
  195. END_IF
  196. 60:
  197. IF gTisch_1_RFID_Write[0] = 0 AND gTisch_1_RFID_Write[1] = 0 AND gTisch_1_RFID_Write[2] = 0 AND gTisch_1_RFID_Write[3] = 0 AND gTisch_1_RFID_Write[4] = 0 AND gTisch_1_RFID_Write[5] = 0 AND gTisch_1_RFID_Write[6] = 0 AND gTisch_1_RFID_Write[7] = 0 AND gTisch_1_RFID_Write[8] = 0 AND gTisch_1_RFID_Write[9] = 0 THEN
  198. gMerker_Tisch_1_alles_nullen := FALSE;
  199. gMerker_OPCUA_Schreibauftrag := FALSE;
  200. gMerker_Tisch_1_lesen_fertig := FALSE;
  201. // gMerker_Tisch_1_Auftrag_Lesen := TRUE;
  202. RFID_Schreiben := 0; // war 70
  203. END_IF
  204. // 70:
  205. // IF gMerker_Tisch_1_RFID_Vorhanden = FALSE THEN
  206. // // gMerker_Tisch_1_Auftrag_Lesen := FALSE;
  207. // RFID_Schreiben := 0;
  208. // END_IF
  209. END_CASE
  210. //********************************** Tisch 2 ***********************************************
  211. (* Lesen *)
  212. gMerker_Tisch_2_RFID_Vorhanden := gTisch_2_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  213. IF gMerker_Tisch_2_Auftrag_Lesen = TRUE THEN
  214. // gMerker_Lesen_Fertig := FALSE;
  215. gTisch_2_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  216. gTisch_2_RFID_Write[2] := 0;
  217. gTisch_2_RFID_Write[3] := 0;
  218. gTisch_2_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  219. gTisch_2_RFID_Write[5] := 0;
  220. gTisch_2_RFID_Write[6] := 0;
  221. gTisch_2_RFID_Write[7] := 0;
  222. gTisch_2_RFID_Write[8] := 0;
  223. gTisch_2_RFID_Write[9] := 1;
  224. gTisch_2_RFID_Write[0].0 := TRUE;
  225. END_IF
  226. (* Write Variable nullen *)
  227. IF gMerker_Tisch_2_alles_nullen = TRUE THEN
  228. gTisch_2_RFID_Write[1] := 0;
  229. gTisch_2_RFID_Write[2] := 0;
  230. gTisch_2_RFID_Write[3] := 0;
  231. gTisch_2_RFID_Write[4] := 0;
  232. gTisch_2_RFID_Write[5] := 0;
  233. gTisch_2_RFID_Write[6] := 0;
  234. gTisch_2_RFID_Write[7] := 0;
  235. gTisch_2_RFID_Write[8] := 0;
  236. gTisch_2_RFID_Write[0] := 0;
  237. END_IF
  238. gTisch_2_RFID_Write[9] := gTisch_2_RFID_Write[0];
  239. CASE Tisch_2_RFID OF
  240. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  241. 0: IF gTisch_2_RFID_Read[0] = 129 AND gTisch_2_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  242. gMerker_Tisch_2_STRING_HELPER := '';
  243. gMerker_Tisch_2_RFID_UID_STR := '';
  244. FOR i := 1 TO 8 DO
  245. gMerker_Tisch_2_STRING_HELPER := USINT_TO_STRING (gTisch_2_RFID_Read[i]);
  246. IF LEN(gMerker_Tisch_2_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  247. gMerker_Tisch_2_STRING_HELPER := CONCAT('00', gMerker_Tisch_2_STRING_HELPER);
  248. ELSIF LEN(gMerker_Tisch_2_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  249. gMerker_Tisch_2_STRING_HELPER := CONCAT('0', gMerker_Tisch_2_STRING_HELPER);
  250. END_IF;
  251. gMerker_Tisch_2_RFID_UID_STR := CONCAT( gMerker_Tisch_2_RFID_UID_STR, gMerker_Tisch_2_STRING_HELPER );
  252. END_FOR
  253. Tisch_2_RFID := 5;
  254. END_IF
  255. //Cech-Implement-Ende
  256. 5: IF gMerker_Tisch_2_RFID_Vorhanden = TRUE AND gTisch_2.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_2_RFID_Reset = FALSE (*AND gMerker_Tisch_2_lesen_fertig = FALSE*) THEN
  257. gMerker_Tisch_2_Auftrag_Lesen := TRUE;
  258. Tisch_2_RFID := 10;
  259. END_IF
  260. 10: lWarten_RFID_Fehler_Tisch_2 := lWarten_RFID_Fehler_Tisch_2 + (RTInfo_0.cycle_time/1000);
  261. IF gTisch_2_RFID_Read[0] = 135 THEN
  262. gMerker_RFID_Value_Tisch_2 := gTisch_2_RFID_Read[1];
  263. // gMerker_RFID_Tisch_2_gelesen := TRUE;
  264. // gMerker_Tisch_2_lesen_fertig := TRUE;
  265. lWarten_RFID_Fehler_Tisch_2 := 0;
  266. Tisch_2_RFID := 15;
  267. ELSIF lWarten_RFID_Fehler_Tisch_2 >= 5000 AND gTisch_2_RFID_Read[0] <> 135 THEN
  268. gMerker_Tisch_2_Auftrag_Lesen := FALSE;
  269. gMerker_Tisch_2_RFID_Reset := TRUE;
  270. lWarten_RFID_Fehler_Tisch_2 := 0;
  271. Tisch_2_RFID := 100;
  272. END_IF
  273. 15:
  274. IF gMerker_RFID_Value_Tisch_2 <> 0 THEN
  275. gMerker_RFID_Tisch_2_gelesen := TRUE;
  276. gMerker_Tisch_2_lesen_fertig := TRUE;
  277. Tisch_2_RFID := 20;
  278. ELSIF gMerker_RFID_Value_Tisch_2 = 0 THEN
  279. gMerker_RFID_Tisch_2_gelesen := FALSE;
  280. gMerker_Tisch_2_lesen_fertig := FALSE;
  281. Tisch_2_RFID := 100;
  282. END_IF
  283. 20: lWarten_fuer_OPCUA_Tisch_2 := lWarten_fuer_OPCUA_Tisch_2 + (RTInfo_0.cycle_time/1000);
  284. IF gMerker_Tisch_2_RFID_Vorhanden = FALSE AND gTisch_2.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_2 >= Wartezeit_OPCUA THEN
  285. gMerker_Tisch_2_Auftrag_Lesen := FALSE;
  286. gMerker_RFID_Value_Tisch_2 := 0;
  287. gTisch_2_RFID_Write[0] := 4;
  288. gMerker_Tisch_2_RFID_UID_STR := '0';
  289. Tisch_2_RFID := 30;
  290. END_IF
  291. 30:
  292. IF gTisch_2_RFID_Read[0] = 0 THEN
  293. gTisch_2_RFID_Write[0] := 0;
  294. Tisch_2_RFID := 0;
  295. END_IF
  296. 100:
  297. IF gMerker_Tisch_2_Auftrag_Lesen = FALSE AND gMerker_Tisch_2_RFID_Reset = TRUE THEN
  298. gTisch_2_RFID_Write[0] := 4;
  299. gMerker_RFID_Value_Tisch_2 := 0;
  300. Tisch_2_RFID := 110;
  301. gMerker_Tisch_2_RFID_UID_STR := '0';
  302. END_IF
  303. 110:
  304. IF gTisch_2_RFID_Read[0] = 0 THEN
  305. gMerker_Tisch_2_alles_nullen := TRUE;
  306. Tisch_2_RFID := 120;
  307. END_IF
  308. 120:
  309. IF gTisch_2_RFID_Write[0] = 0 AND gTisch_2_RFID_Write[1] = 0 AND gTisch_2_RFID_Write[2] = 0 AND gTisch_2_RFID_Write[3] = 0 AND gTisch_2_RFID_Write[4] = 0 AND gTisch_2_RFID_Write[5] = 0 AND gTisch_2_RFID_Write[6] = 0 AND gTisch_2_RFID_Write[7] = 0 AND gTisch_2_RFID_Write[8] = 0 AND gTisch_2_RFID_Write[9] = 0 THEN
  310. gMerker_Tisch_2_alles_nullen := FALSE;
  311. gMerker_Tisch_2_RFID_Reset := FALSE;
  312. Tisch_2_RFID := 0;
  313. END_IF
  314. END_CASE
  315. //********************************** Tisch 3 ***********************************************
  316. (* Lesen *)
  317. gMerker_Tisch_3_RFID_Vorhanden := gTisch_3_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  318. IF gMerker_Tisch_3_Auftrag_Lesen = TRUE THEN
  319. // gMerker_Lesen_Fertig := FALSE;
  320. gTisch_3_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  321. gTisch_3_RFID_Write[2] := 0;
  322. gTisch_3_RFID_Write[3] := 0;
  323. gTisch_3_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  324. gTisch_3_RFID_Write[5] := 0;
  325. gTisch_3_RFID_Write[6] := 0;
  326. gTisch_3_RFID_Write[7] := 0;
  327. gTisch_3_RFID_Write[8] := 0;
  328. gTisch_3_RFID_Write[9] := 1;
  329. gTisch_3_RFID_Write[0].0 := TRUE;
  330. END_IF
  331. (* Write Variable nullen *)
  332. IF gMerker_Tisch_3_alles_nullen = TRUE THEN
  333. gTisch_3_RFID_Write[1] := 0;
  334. gTisch_3_RFID_Write[2] := 0;
  335. gTisch_3_RFID_Write[3] := 0;
  336. gTisch_3_RFID_Write[4] := 0;
  337. gTisch_3_RFID_Write[5] := 0;
  338. gTisch_3_RFID_Write[6] := 0;
  339. gTisch_3_RFID_Write[7] := 0;
  340. gTisch_3_RFID_Write[8] := 0;
  341. gTisch_3_RFID_Write[0] := 0;
  342. END_IF
  343. gTisch_3_RFID_Write[9] := gTisch_3_RFID_Write[0];
  344. CASE Tisch_3_RFID OF
  345. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  346. 0: IF gTisch_3_RFID_Read[0] = 129 AND gTisch_3_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  347. gMerker_Tisch_3_STRING_HELPER := '';
  348. gMerker_Tisch_3_RFID_UID_STR := '';
  349. FOR i := 1 TO 8 DO
  350. gMerker_Tisch_3_STRING_HELPER := USINT_TO_STRING (gTisch_3_RFID_Read[i]);
  351. IF LEN(gMerker_Tisch_3_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  352. gMerker_Tisch_3_STRING_HELPER := CONCAT('00', gMerker_Tisch_3_STRING_HELPER);
  353. ELSIF LEN(gMerker_Tisch_3_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  354. gMerker_Tisch_3_STRING_HELPER := CONCAT('0', gMerker_Tisch_3_STRING_HELPER);
  355. END_IF;
  356. gMerker_Tisch_3_RFID_UID_STR := CONCAT( gMerker_Tisch_3_RFID_UID_STR, gMerker_Tisch_3_STRING_HELPER );
  357. END_FOR
  358. Tisch_3_RFID := 5;
  359. END_IF
  360. //Cech-Implement-Ende
  361. 5: IF gMerker_Tisch_3_RFID_Vorhanden = TRUE AND gTisch_3.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_3_RFID_Reset = FALSE (*AND gMerker_Tisch_3_lesen_fertig = FALSE*) THEN
  362. gMerker_Tisch_3_Auftrag_Lesen := TRUE;
  363. Tisch_3_RFID := 10;
  364. END_IF
  365. 10: lWarten_RFID_Fehler_Tisch_3 := lWarten_RFID_Fehler_Tisch_3 + (RTInfo_0.cycle_time/1000);
  366. IF gTisch_3_RFID_Read[0] = 135 THEN
  367. gMerker_RFID_Value_Tisch_3 := gTisch_3_RFID_Read[1];
  368. // gMerker_RFID_Tisch_3_gelesen := TRUE;
  369. // gMerker_Tisch_3_lesen_fertig := TRUE;
  370. lWarten_RFID_Fehler_Tisch_3 := 0;
  371. Tisch_3_RFID := 15;
  372. ELSIF lWarten_RFID_Fehler_Tisch_3 >= 5000 AND gTisch_3_RFID_Read[0] <> 135 THEN
  373. gMerker_Tisch_3_Auftrag_Lesen := FALSE;
  374. gMerker_Tisch_3_RFID_Reset := TRUE;
  375. lWarten_RFID_Fehler_Tisch_3 := 0;
  376. Tisch_3_RFID := 100;
  377. END_IF
  378. 15:
  379. IF gMerker_RFID_Value_Tisch_3 <> 0 THEN
  380. gMerker_RFID_Tisch_3_gelesen := TRUE;
  381. gMerker_Tisch_3_lesen_fertig := TRUE;
  382. Tisch_3_RFID := 20;
  383. ELSIF gMerker_RFID_Value_Tisch_3 = 0 THEN
  384. gMerker_RFID_Tisch_3_gelesen := FALSE;
  385. gMerker_Tisch_3_lesen_fertig := FALSE;
  386. Tisch_3_RFID := 100;
  387. END_IF
  388. 20: lWarten_fuer_OPCUA_Tisch_3 := lWarten_fuer_OPCUA_Tisch_3 + (RTInfo_0.cycle_time/1000);
  389. IF gMerker_Tisch_3_RFID_Vorhanden = FALSE AND gTisch_3.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_3 >= Wartezeit_OPCUA THEN
  390. gMerker_Tisch_3_Auftrag_Lesen := FALSE;
  391. gMerker_RFID_Value_Tisch_3 := 0;
  392. gTisch_3_RFID_Write[0] := 4;
  393. gMerker_Tisch_3_RFID_UID_STR := '0';
  394. Tisch_3_RFID := 30;
  395. END_IF
  396. 30:
  397. IF gTisch_3_RFID_Read[0] = 0 THEN
  398. gTisch_3_RFID_Write[0] := 0;
  399. Tisch_3_RFID := 0;
  400. END_IF
  401. 100:
  402. IF gMerker_Tisch_3_Auftrag_Lesen = FALSE AND gMerker_Tisch_3_RFID_Reset = TRUE THEN
  403. gTisch_3_RFID_Write[0] := 4;
  404. gMerker_RFID_Value_Tisch_3 := 0;
  405. gMerker_Tisch_3_RFID_UID_STR := '0';
  406. Tisch_3_RFID := 110;
  407. END_IF
  408. 110:
  409. IF gTisch_3_RFID_Read[0] = 0 THEN
  410. gMerker_Tisch_3_alles_nullen := TRUE;
  411. Tisch_3_RFID := 120;
  412. END_IF
  413. 120:
  414. IF gTisch_3_RFID_Write[0] = 0 AND gTisch_3_RFID_Write[1] = 0 AND gTisch_3_RFID_Write[2] = 0 AND gTisch_3_RFID_Write[3] = 0 AND gTisch_3_RFID_Write[4] = 0 AND gTisch_3_RFID_Write[5] = 0 AND gTisch_3_RFID_Write[6] = 0 AND gTisch_3_RFID_Write[7] = 0 AND gTisch_3_RFID_Write[8] = 0 AND gTisch_3_RFID_Write[9] = 0 THEN
  415. gMerker_Tisch_3_alles_nullen := FALSE;
  416. gMerker_Tisch_3_RFID_Reset := FALSE;
  417. Tisch_3_RFID := 0;
  418. END_IF
  419. END_CASE
  420. //********************************** Tisch 4 ***********************************************
  421. (* Lesen *)
  422. gMerker_Tisch_4_RFID_Vorhanden := gTisch_4_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  423. IF gMerker_Tisch_4_Auftrag_Lesen = TRUE THEN
  424. // gMerker_Lesen_Fertig := FALSE;
  425. gTisch_4_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  426. gTisch_4_RFID_Write[2] := 0;
  427. gTisch_4_RFID_Write[3] := 0;
  428. gTisch_4_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  429. gTisch_4_RFID_Write[5] := 0;
  430. gTisch_4_RFID_Write[6] := 0;
  431. gTisch_4_RFID_Write[7] := 0;
  432. gTisch_4_RFID_Write[8] := 0;
  433. gTisch_4_RFID_Write[9] := 1;
  434. gTisch_4_RFID_Write[0].0 := TRUE;
  435. END_IF
  436. (* Write Variable nullen *)
  437. IF gMerker_Tisch_4_alles_nullen = TRUE THEN
  438. gTisch_4_RFID_Write[1] := 0;
  439. gTisch_4_RFID_Write[2] := 0;
  440. gTisch_4_RFID_Write[3] := 0;
  441. gTisch_4_RFID_Write[4] := 0;
  442. gTisch_4_RFID_Write[5] := 0;
  443. gTisch_4_RFID_Write[6] := 0;
  444. gTisch_4_RFID_Write[7] := 0;
  445. gTisch_4_RFID_Write[8] := 0;
  446. gTisch_4_RFID_Write[0] := 0;
  447. END_IF
  448. gTisch_4_RFID_Write[9] := gTisch_4_RFID_Write[0];
  449. CASE Tisch_4_RFID OF
  450. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  451. 0: IF gTisch_4_RFID_Read[0] = 129 AND gTisch_4_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  452. gMerker_Tisch_4_STRING_HELPER := '';
  453. gMerker_Tisch_4_RFID_UID_STR := '';
  454. FOR i := 1 TO 8 DO
  455. gMerker_Tisch_4_STRING_HELPER := USINT_TO_STRING (gTisch_4_RFID_Read[i]);
  456. IF LEN(gMerker_Tisch_4_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  457. gMerker_Tisch_4_STRING_HELPER := CONCAT('00', gMerker_Tisch_4_STRING_HELPER);
  458. ELSIF LEN(gMerker_Tisch_4_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  459. gMerker_Tisch_4_STRING_HELPER := CONCAT('0', gMerker_Tisch_4_STRING_HELPER);
  460. END_IF;
  461. gMerker_Tisch_4_RFID_UID_STR := CONCAT( gMerker_Tisch_4_RFID_UID_STR, gMerker_Tisch_4_STRING_HELPER );
  462. END_FOR
  463. Tisch_4_RFID := 5;
  464. END_IF
  465. //Cech-Implement-Ende
  466. 5: IF gMerker_Tisch_4_RFID_Vorhanden = TRUE AND gTisch_4.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_4_RFID_Reset = FALSE (*AND gMerker_Tisch_4_lesen_fertig = FALSE*) THEN
  467. gMerker_Tisch_4_Auftrag_Lesen := TRUE;
  468. Tisch_4_RFID := 10;
  469. END_IF
  470. 10: lWarten_RFID_Fehler_Tisch_4 := lWarten_RFID_Fehler_Tisch_4 + (RTInfo_0.cycle_time/1000);
  471. IF gTisch_4_RFID_Read[0] = 135 THEN
  472. gMerker_RFID_Value_Tisch_4 := gTisch_4_RFID_Read[1];
  473. // gMerker_RFID_Tisch_4_gelesen := TRUE;
  474. // gMerker_Tisch_4_lesen_fertig := TRUE;
  475. lWarten_RFID_Fehler_Tisch_4 := 0;
  476. Tisch_4_RFID := 15;
  477. ELSIF lWarten_RFID_Fehler_Tisch_4 >= 5000 AND gTisch_4_RFID_Read[0] <> 135 THEN
  478. gMerker_Tisch_4_Auftrag_Lesen := FALSE;
  479. gMerker_Tisch_4_RFID_Reset := TRUE;
  480. lWarten_RFID_Fehler_Tisch_4 := 0;
  481. Tisch_4_RFID := 100;
  482. END_IF
  483. 15:
  484. IF gMerker_RFID_Value_Tisch_4 <> 0 THEN
  485. gMerker_RFID_Tisch_4_gelesen := TRUE;
  486. gMerker_Tisch_4_lesen_fertig := TRUE;
  487. Tisch_4_RFID := 20;
  488. ELSIF gMerker_RFID_Value_Tisch_4 = 0 THEN
  489. gMerker_RFID_Tisch_4_gelesen := FALSE;
  490. gMerker_Tisch_4_lesen_fertig := FALSE;
  491. Tisch_4_RFID := 100;
  492. END_IF
  493. 20: lWarten_fuer_OPCUA_Tisch_4 := lWarten_fuer_OPCUA_Tisch_4 + (RTInfo_0.cycle_time/1000);
  494. IF gMerker_Tisch_4_RFID_Vorhanden = FALSE AND gTisch_4.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_4 >= Wartezeit_OPCUA THEN
  495. gMerker_Tisch_4_Auftrag_Lesen := FALSE;
  496. gMerker_RFID_Value_Tisch_4 := 0;
  497. gTisch_4_RFID_Write[0] := 4;
  498. gMerker_Tisch_4_RFID_UID_STR := '0';
  499. Tisch_4_RFID := 30;
  500. END_IF
  501. 30:
  502. IF gTisch_4_RFID_Read[0] = 0 THEN
  503. gTisch_4_RFID_Write[0] := 0;
  504. Tisch_4_RFID := 0;
  505. END_IF
  506. 100:
  507. IF gMerker_Tisch_4_Auftrag_Lesen = FALSE AND gMerker_Tisch_4_RFID_Reset = TRUE THEN
  508. gTisch_4_RFID_Write[0] := 4;
  509. gMerker_RFID_Value_Tisch_4 := 0;
  510. gMerker_Tisch_4_RFID_UID_STR := '0';
  511. Tisch_4_RFID := 110;
  512. END_IF
  513. 110:
  514. IF gTisch_4_RFID_Read[0] = 0 THEN
  515. gMerker_Tisch_4_alles_nullen := TRUE;
  516. Tisch_4_RFID := 120;
  517. END_IF
  518. 120:
  519. IF gTisch_4_RFID_Write[0] = 0 AND gTisch_4_RFID_Write[1] = 0 AND gTisch_4_RFID_Write[2] = 0 AND gTisch_4_RFID_Write[3] = 0 AND gTisch_4_RFID_Write[4] = 0 AND gTisch_4_RFID_Write[5] = 0 AND gTisch_4_RFID_Write[6] = 0 AND gTisch_4_RFID_Write[7] = 0 AND gTisch_4_RFID_Write[8] = 0 AND gTisch_4_RFID_Write[9] = 0 THEN
  520. gMerker_Tisch_4_alles_nullen := FALSE;
  521. gMerker_Tisch_4_RFID_Reset := FALSE;
  522. Tisch_4_RFID := 0;
  523. END_IF
  524. END_CASE
  525. //********************************** Tisch 5 ***********************************************
  526. (* Lesen *)
  527. gMerker_Tisch_5_RFID_Vorhanden := gTisch_5_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  528. IF gMerker_Tisch_5_Auftrag_Lesen = TRUE THEN
  529. // gMerker_Lesen_Fertig := FALSE;
  530. gTisch_5_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  531. gTisch_5_RFID_Write[2] := 0;
  532. gTisch_5_RFID_Write[3] := 0;
  533. gTisch_5_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  534. gTisch_5_RFID_Write[5] := 0;
  535. gTisch_5_RFID_Write[6] := 0;
  536. gTisch_5_RFID_Write[7] := 0;
  537. gTisch_5_RFID_Write[8] := 0;
  538. gTisch_5_RFID_Write[9] := 1;
  539. gTisch_5_RFID_Write[0].0 := TRUE;
  540. END_IF
  541. (* Write Variable nullen *)
  542. IF gMerker_Tisch_5_alles_nullen = TRUE THEN
  543. gTisch_5_RFID_Write[1] := 0;
  544. gTisch_5_RFID_Write[2] := 0;
  545. gTisch_5_RFID_Write[3] := 0;
  546. gTisch_5_RFID_Write[4] := 0;
  547. gTisch_5_RFID_Write[5] := 0;
  548. gTisch_5_RFID_Write[6] := 0;
  549. gTisch_5_RFID_Write[7] := 0;
  550. gTisch_5_RFID_Write[8] := 0;
  551. gTisch_5_RFID_Write[0] := 0;
  552. END_IF
  553. gTisch_5_RFID_Write[9] := gTisch_5_RFID_Write[0];
  554. CASE Tisch_5_RFID OF
  555. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  556. 0: IF gTisch_5_RFID_Read[0] = 129 AND gTisch_5_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  557. gMerker_Tisch_5_STRING_HELPER := '';
  558. gMerker_Tisch_5_RFID_UID_STR := '';
  559. FOR i := 1 TO 8 DO
  560. gMerker_Tisch_5_STRING_HELPER := USINT_TO_STRING (gTisch_5_RFID_Read[i]);
  561. IF LEN(gMerker_Tisch_5_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  562. gMerker_Tisch_5_STRING_HELPER := CONCAT('00', gMerker_Tisch_5_STRING_HELPER);
  563. ELSIF LEN(gMerker_Tisch_5_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  564. gMerker_Tisch_5_STRING_HELPER := CONCAT('0', gMerker_Tisch_5_STRING_HELPER);
  565. END_IF;
  566. gMerker_Tisch_5_RFID_UID_STR := CONCAT( gMerker_Tisch_5_RFID_UID_STR, gMerker_Tisch_5_STRING_HELPER );
  567. END_FOR
  568. Tisch_5_RFID := 5;
  569. END_IF
  570. //Cech-Implement-Ende
  571. 5: IF gMerker_Tisch_5_RFID_Vorhanden = TRUE AND gTisch_5.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_5_RFID_Reset = FALSE (*AND gMerker_Tisch_5_lesen_fertig = FALSE*) THEN
  572. gMerker_Tisch_5_Auftrag_Lesen := TRUE;
  573. Tisch_5_RFID := 10;
  574. END_IF
  575. 10: lWarten_RFID_Fehler_Tisch_5 := lWarten_RFID_Fehler_Tisch_5 + (RTInfo_0.cycle_time/1000);
  576. IF gTisch_5_RFID_Read[0] = 135 THEN
  577. gMerker_RFID_Value_Tisch_5 := gTisch_5_RFID_Read[1];
  578. // gMerker_RFID_Tisch_5_gelesen := TRUE;
  579. // gMerker_Tisch_5_lesen_fertig := TRUE;
  580. lWarten_RFID_Fehler_Tisch_5 := 0;
  581. Tisch_5_RFID := 15;
  582. ELSIF lWarten_RFID_Fehler_Tisch_5 >= 5000 AND gTisch_5_RFID_Read[0] <> 135 THEN
  583. gMerker_Tisch_5_Auftrag_Lesen := FALSE;
  584. gMerker_Tisch_5_RFID_Reset := TRUE;
  585. lWarten_RFID_Fehler_Tisch_5 := 0;
  586. Tisch_5_RFID := 100;
  587. END_IF
  588. 15:
  589. IF gMerker_RFID_Value_Tisch_5 <> 0 THEN
  590. gMerker_RFID_Tisch_5_gelesen := TRUE;
  591. gMerker_Tisch_5_lesen_fertig := TRUE;
  592. Tisch_5_RFID := 20;
  593. ELSIF gMerker_RFID_Value_Tisch_5 = 0 THEN
  594. gMerker_RFID_Tisch_5_gelesen := FALSE;
  595. gMerker_Tisch_5_lesen_fertig := FALSE;
  596. Tisch_5_RFID := 100;
  597. END_IF
  598. 20: lWarten_fuer_OPCUA_Tisch_5 := lWarten_fuer_OPCUA_Tisch_5 + (RTInfo_0.cycle_time/1000);
  599. IF gMerker_Tisch_5_RFID_Vorhanden = FALSE AND gTisch_5.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_5 >= Wartezeit_OPCUA THEN
  600. gMerker_Tisch_5_Auftrag_Lesen := FALSE;
  601. gMerker_RFID_Value_Tisch_5 := 0;
  602. gTisch_5_RFID_Write[0] := 4;
  603. gMerker_Tisch_5_RFID_UID_STR := '0';
  604. Tisch_5_RFID := 30;
  605. END_IF
  606. 30:
  607. IF gTisch_5_RFID_Read[0] = 0 THEN
  608. gTisch_5_RFID_Write[0] := 0;
  609. Tisch_5_RFID := 0;
  610. END_IF
  611. 100:
  612. IF gMerker_Tisch_5_Auftrag_Lesen = FALSE AND gMerker_Tisch_5_RFID_Reset = TRUE THEN
  613. gTisch_5_RFID_Write[0] := 4;
  614. gMerker_RFID_Value_Tisch_5 := 0;
  615. gMerker_Tisch_5_RFID_UID_STR := '0';
  616. Tisch_5_RFID := 110;
  617. END_IF
  618. 110:
  619. IF gTisch_5_RFID_Read[0] = 0 THEN
  620. gMerker_Tisch_5_alles_nullen := TRUE;
  621. Tisch_5_RFID := 120;
  622. END_IF
  623. 120:
  624. IF gTisch_5_RFID_Write[0] = 0 AND gTisch_5_RFID_Write[1] = 0 AND gTisch_5_RFID_Write[2] = 0 AND gTisch_5_RFID_Write[3] = 0 AND gTisch_5_RFID_Write[4] = 0 AND gTisch_5_RFID_Write[5] = 0 AND gTisch_5_RFID_Write[6] = 0 AND gTisch_5_RFID_Write[7] = 0 AND gTisch_5_RFID_Write[8] = 0 AND gTisch_5_RFID_Write[9] = 0 THEN
  625. gMerker_Tisch_5_alles_nullen := FALSE;
  626. gMerker_Tisch_5_RFID_Reset := FALSE;
  627. Tisch_5_RFID := 0;
  628. END_IF
  629. END_CASE
  630. //********************************** Tisch 6 ***********************************************
  631. (* Lesen *)
  632. gMerker_Tisch_6_RFID_Vorhanden := gTisch_6_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  633. CASE Tisch_6_RFID OF
  634. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  635. 0: IF gTisch_6_RFID_Read[0] = 129 (* /// AND gTisch_6_RFID_Write[0].0 = FALSE *) THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  636. gMerker_Tisch_6_STRING_HELPER := '';
  637. gMerker_Tisch_6_RFID_UID_STR := '';
  638. FOR i := 1 TO 8 DO
  639. gMerker_Tisch_6_STRING_HELPER := USINT_TO_STRING (gTisch_6_RFID_Read[i]);
  640. IF LEN(gMerker_Tisch_6_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  641. gMerker_Tisch_6_STRING_HELPER := CONCAT('00', gMerker_Tisch_6_STRING_HELPER);
  642. ELSIF LEN(gMerker_Tisch_6_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  643. gMerker_Tisch_6_STRING_HELPER := CONCAT('0', gMerker_Tisch_6_STRING_HELPER);
  644. END_IF;
  645. gMerker_Tisch_6_RFID_UID_STR := CONCAT( gMerker_Tisch_6_RFID_UID_STR, gMerker_Tisch_6_STRING_HELPER );
  646. END_FOR
  647. Tisch_6_RFID := 30;
  648. END_IF
  649. //Cech-Implement-Ende
  650. 30:
  651. IF gMerker_Tisch_6_RFID_Vorhanden = FALSE AND gTisch_6.Inputs.Nach_Stopper = TRUE THEN
  652. /// gTisch_6_RFID_Write[0] := 0;
  653. gMerker_Tisch_6_RFID_UID_STR := '0';
  654. Tisch_6_RFID := 0;
  655. END_IF
  656. END_CASE
  657. //********************************** Tisch 7 ***********************************************
  658. (* Lesen *)
  659. gMerker_Tisch_7_RFID_Vorhanden := gTisch_7_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  660. IF gMerker_Tisch_7_Auftrag_Lesen = TRUE THEN
  661. // gMerker_Lesen_Fertig := FALSE;
  662. gTisch_7_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  663. gTisch_7_RFID_Write[2] := 0;
  664. gTisch_7_RFID_Write[3] := 0;
  665. gTisch_7_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  666. gTisch_7_RFID_Write[5] := 0;
  667. gTisch_7_RFID_Write[6] := 0;
  668. gTisch_7_RFID_Write[7] := 0;
  669. gTisch_7_RFID_Write[8] := 0;
  670. gTisch_7_RFID_Write[9] := 1;
  671. gTisch_7_RFID_Write[0].0 := TRUE;
  672. END_IF
  673. (* Write Variable nullen *)
  674. IF gMerker_Tisch_7_alles_nullen = TRUE THEN
  675. gTisch_7_RFID_Write[1] := 0;
  676. gTisch_7_RFID_Write[2] := 0;
  677. gTisch_7_RFID_Write[3] := 0;
  678. gTisch_7_RFID_Write[4] := 0;
  679. gTisch_7_RFID_Write[5] := 0;
  680. gTisch_7_RFID_Write[6] := 0;
  681. gTisch_7_RFID_Write[7] := 0;
  682. gTisch_7_RFID_Write[8] := 0;
  683. gTisch_7_RFID_Write[0] := 0;
  684. END_IF
  685. gTisch_7_RFID_Write[9] := gTisch_7_RFID_Write[0];
  686. CASE Tisch_7_RFID OF
  687. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  688. 0: IF gTisch_7_RFID_Read[0] = 129 AND gTisch_7_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  689. gMerker_Tisch_7_STRING_HELPER := '';
  690. gMerker_Tisch_7_RFID_UID_STR := '';
  691. FOR i := 1 TO 8 DO
  692. gMerker_Tisch_7_STRING_HELPER := USINT_TO_STRING (gTisch_7_RFID_Read[i]);
  693. IF LEN(gMerker_Tisch_7_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  694. gMerker_Tisch_7_STRING_HELPER := CONCAT('00', gMerker_Tisch_7_STRING_HELPER);
  695. ELSIF LEN(gMerker_Tisch_7_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  696. gMerker_Tisch_7_STRING_HELPER := CONCAT('0', gMerker_Tisch_7_STRING_HELPER);
  697. END_IF;
  698. gMerker_Tisch_7_RFID_UID_STR := CONCAT( gMerker_Tisch_7_RFID_UID_STR, gMerker_Tisch_7_STRING_HELPER );
  699. END_FOR
  700. Tisch_7_RFID := 5;
  701. END_IF
  702. //Cech-Implement-Ende
  703. 5: IF gMerker_Tisch_7_RFID_Vorhanden = TRUE AND gTisch_7.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_7_RFID_Reset = FALSE (*AND gMerker_Tisch_7_lesen_fertig = FALSE*) THEN
  704. gMerker_Tisch_7_Auftrag_Lesen := TRUE;
  705. Tisch_7_RFID := 10;
  706. END_IF
  707. 10: lWarten_RFID_Fehler_Tisch_7 := lWarten_RFID_Fehler_Tisch_7 + (RTInfo_0.cycle_time/1000);
  708. IF gTisch_7_RFID_Read[0] = 135 THEN
  709. gMerker_RFID_Value_Tisch_7 := gTisch_7_RFID_Read[1];
  710. // gMerker_RFID_Tisch_7_gelesen := TRUE;
  711. // gMerker_Tisch_7_lesen_fertig := TRUE;
  712. lWarten_RFID_Fehler_Tisch_7 := 0;
  713. Tisch_7_RFID := 15;
  714. ELSIF lWarten_RFID_Fehler_Tisch_7 >= 5000 AND gTisch_7_RFID_Read[0] <> 135 THEN
  715. gMerker_Tisch_7_Auftrag_Lesen := FALSE;
  716. gMerker_Tisch_7_RFID_Reset := TRUE;
  717. lWarten_RFID_Fehler_Tisch_7 := 0;
  718. Tisch_7_RFID := 100;
  719. END_IF
  720. 15:
  721. IF gMerker_RFID_Value_Tisch_7 <> 0 THEN
  722. gMerker_RFID_Tisch_7_gelesen := TRUE;
  723. gMerker_Tisch_7_lesen_fertig := TRUE;
  724. Tisch_7_RFID := 20;
  725. ELSIF gMerker_RFID_Value_Tisch_7 = 0 THEN
  726. gMerker_RFID_Tisch_7_gelesen := FALSE;
  727. gMerker_Tisch_7_lesen_fertig := FALSE;
  728. Tisch_7_RFID := 100;
  729. END_IF
  730. 20: lWarten_fuer_OPCUA_Tisch_7 := lWarten_fuer_OPCUA_Tisch_7 + (RTInfo_0.cycle_time/1000);
  731. IF gMerker_Tisch_7_RFID_Vorhanden = FALSE AND gTisch_7.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_7 >= Wartezeit_OPCUA THEN
  732. gMerker_Tisch_7_Auftrag_Lesen := FALSE;
  733. gMerker_RFID_Value_Tisch_7 := 0;
  734. gTisch_7_RFID_Write[0] := 4;
  735. gMerker_Tisch_7_RFID_UID_STR := '0';
  736. Tisch_7_RFID := 30;
  737. END_IF
  738. 30:
  739. IF gTisch_7_RFID_Read[0] = 0 THEN
  740. gTisch_7_RFID_Write[0] := 0;
  741. Tisch_7_RFID := 0;
  742. END_IF
  743. 100:
  744. IF gMerker_Tisch_7_Auftrag_Lesen = FALSE AND gMerker_Tisch_7_RFID_Reset = TRUE THEN
  745. gTisch_7_RFID_Write[0] := 4;
  746. gMerker_RFID_Value_Tisch_7 := 0;
  747. gMerker_Tisch_7_RFID_UID_STR := '0';
  748. Tisch_7_RFID := 110;
  749. END_IF
  750. 110:
  751. IF gTisch_7_RFID_Read[0] = 0 THEN
  752. gMerker_Tisch_7_alles_nullen := TRUE;
  753. Tisch_7_RFID := 120;
  754. END_IF
  755. 120:
  756. IF gTisch_7_RFID_Write[0] = 0 AND gTisch_7_RFID_Write[1] = 0 AND gTisch_7_RFID_Write[2] = 0 AND gTisch_7_RFID_Write[3] = 0 AND gTisch_7_RFID_Write[4] = 0 AND gTisch_7_RFID_Write[5] = 0 AND gTisch_7_RFID_Write[6] = 0 AND gTisch_7_RFID_Write[7] = 0 AND gTisch_7_RFID_Write[8] = 0 AND gTisch_7_RFID_Write[9] = 0 THEN
  757. gMerker_Tisch_7_alles_nullen := FALSE;
  758. gMerker_Tisch_7_RFID_Reset := FALSE;
  759. Tisch_7_RFID := 0;
  760. END_IF
  761. END_CASE
  762. //********************************** Tisch 8 ***********************************************
  763. (* Lesen *)
  764. gMerker_Tisch_8_RFID_Vorhanden := gTisch_8_RFID_Read[0].0; (* Auslesen ob Chip vor Lesekopf *)
  765. IF gMerker_Tisch_8_Auftrag_Lesen = TRUE THEN
  766. // gMerker_Lesen_Fertig := FALSE;
  767. gTisch_8_RFID_Write[1] := 1;(* Befehl Datenträger lesen *)
  768. gTisch_8_RFID_Write[2] := 0;
  769. gTisch_8_RFID_Write[3] := 0;
  770. gTisch_8_RFID_Write[4] := 8; (* Anzahl Bytes Lowbytes *)
  771. gTisch_8_RFID_Write[5] := 0;
  772. gTisch_8_RFID_Write[6] := 0;
  773. gTisch_8_RFID_Write[7] := 0;
  774. gTisch_8_RFID_Write[8] := 0;
  775. gTisch_8_RFID_Write[9] := 1;
  776. gTisch_8_RFID_Write[0].0 := TRUE;
  777. END_IF
  778. (* Write Variable nullen *)
  779. IF gMerker_Tisch_8_alles_nullen = TRUE THEN
  780. gTisch_8_RFID_Write[1] := 0;
  781. gTisch_8_RFID_Write[2] := 0;
  782. gTisch_8_RFID_Write[3] := 0;
  783. gTisch_8_RFID_Write[4] := 0;
  784. gTisch_8_RFID_Write[5] := 0;
  785. gTisch_8_RFID_Write[6] := 0;
  786. gTisch_8_RFID_Write[7] := 0;
  787. gTisch_8_RFID_Write[8] := 0;
  788. gTisch_8_RFID_Write[0] := 0;
  789. END_IF
  790. gTisch_8_RFID_Write[9] := gTisch_8_RFID_Write[0];
  791. CASE Tisch_8_RFID OF
  792. //Cech-Implement-Beginn: Hier soll die UID aus dem TAg nach Tag-Present rausgeholt und auf 8Byte-Array gMerker_Tisch_1_RFID_UID übergeben werden, damit die UID für Centurio über Opc-Ua übergeben werden kannn
  793. 0: IF gTisch_8_RFID_Read[0] = 129 AND gTisch_8_RFID_Write[0].0 = FALSE THEN //Cech-Comment: Wenn der TAG im Lesebereich ist und der Lesekopf betriebsbereit ist ( Read[0] = 1000 0001 ), aber noch kein Lesebefehl ausgegeben wurde
  794. gMerker_Tisch_8_STRING_HELPER := '';
  795. gMerker_Tisch_8_RFID_UID_STR := '';
  796. FOR i := 1 TO 8 DO
  797. gMerker_Tisch_8_STRING_HELPER := USINT_TO_STRING (gTisch_8_RFID_Read[i]);
  798. IF LEN(gMerker_Tisch_8_STRING_HELPER) = 1 THEN //Cech-Comment: Wenn der String nur 1 ZEichen ist, muss mit 2 Nullen links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  799. gMerker_Tisch_8_STRING_HELPER := CONCAT('00', gMerker_Tisch_8_STRING_HELPER);
  800. ELSIF LEN(gMerker_Tisch_8_STRING_HELPER) = 2 THEN //Cech-Comment: Wenn der String nur 2 Zeichen ist, muss mit 1 Null links verlängert werden, sonst wird ID verstümmelt und ist dadurch nicht mehr eindeutig über alle 8 Bytes der UID
  801. gMerker_Tisch_8_STRING_HELPER := CONCAT('0', gMerker_Tisch_8_STRING_HELPER);
  802. END_IF;
  803. gMerker_Tisch_8_RFID_UID_STR := CONCAT( gMerker_Tisch_8_RFID_UID_STR, gMerker_Tisch_8_STRING_HELPER );
  804. END_FOR
  805. Tisch_8_RFID := 5;
  806. END_IF
  807. //Cech-Implement-Ende
  808. 5: IF gMerker_Tisch_8_RFID_Vorhanden = TRUE AND gTisch_8.Inputs.Vor_Stopper = TRUE AND gMerker_Tisch_8_RFID_Reset = FALSE (*AND gMerker_Tisch_8_lesen_fertig = FALSE*) THEN
  809. gMerker_Tisch_8_Auftrag_Lesen := TRUE;
  810. Tisch_8_RFID := 10;
  811. END_IF
  812. 10: lWarten_RFID_Fehler_Tisch_8 := lWarten_RFID_Fehler_Tisch_8 + (RTInfo_0.cycle_time/1000);
  813. IF gTisch_8_RFID_Read[0] = 135 THEN
  814. gMerker_RFID_Value_Tisch_8 := gTisch_8_RFID_Read[1];
  815. // gMerker_RFID_Tisch_8_gelesen := TRUE;
  816. // gMerker_Tisch_8_lesen_fertig := TRUE;
  817. lWarten_RFID_Fehler_Tisch_8 := 0;
  818. Tisch_8_RFID := 15;
  819. ELSIF lWarten_RFID_Fehler_Tisch_8 >= 5000 AND gTisch_8_RFID_Read[0] <> 135 THEN
  820. gMerker_Tisch_8_Auftrag_Lesen := FALSE;
  821. gMerker_Tisch_8_RFID_Reset := TRUE;
  822. lWarten_RFID_Fehler_Tisch_8 := 0;
  823. Tisch_8_RFID := 100;
  824. END_IF
  825. 15:
  826. IF gMerker_RFID_Value_Tisch_8 <> 0 THEN
  827. gMerker_RFID_Tisch_8_gelesen := TRUE;
  828. gMerker_Tisch_8_lesen_fertig := TRUE;
  829. Tisch_8_RFID := 20;
  830. ELSIF gMerker_RFID_Value_Tisch_8 = 0 THEN
  831. gMerker_RFID_Tisch_8_gelesen := FALSE;
  832. gMerker_Tisch_8_lesen_fertig := FALSE;
  833. Tisch_8_RFID := 100;
  834. END_IF
  835. 20: lWarten_fuer_OPCUA_Tisch_8 := lWarten_fuer_OPCUA_Tisch_8 + (RTInfo_0.cycle_time/1000);
  836. IF gMerker_Tisch_8_RFID_Vorhanden = FALSE AND gTisch_8.Inputs.Vor_Stopper = FALSE AND lWarten_fuer_OPCUA_Tisch_8 >= Wartezeit_OPCUA THEN
  837. gMerker_Tisch_8_Auftrag_Lesen := FALSE;
  838. gMerker_RFID_Value_Tisch_8 := 0;
  839. gTisch_8_RFID_Write[0] := 4;
  840. gMerker_Tisch_8_RFID_UID_STR := '0';
  841. Tisch_8_RFID := 30;
  842. END_IF
  843. 30:
  844. IF gTisch_8_RFID_Read[0] = 0 THEN
  845. gTisch_8_RFID_Write[0] := 0;
  846. Tisch_8_RFID := 0;
  847. END_IF
  848. 100:
  849. IF gMerker_Tisch_8_Auftrag_Lesen = FALSE AND gMerker_Tisch_8_RFID_Reset = TRUE THEN
  850. gTisch_8_RFID_Write[0] := 4;
  851. gMerker_RFID_Value_Tisch_8 := 0;
  852. gMerker_Tisch_8_RFID_UID_STR := '0';
  853. Tisch_8_RFID := 110;
  854. END_IF
  855. 110:
  856. IF gTisch_8_RFID_Read[0] = 0 THEN
  857. gMerker_Tisch_8_alles_nullen := TRUE;
  858. Tisch_8_RFID := 120;
  859. END_IF
  860. 120:
  861. IF gTisch_8_RFID_Write[0] = 0 AND gTisch_8_RFID_Write[1] = 0 AND gTisch_8_RFID_Write[2] = 0 AND gTisch_8_RFID_Write[3] = 0 AND gTisch_8_RFID_Write[4] = 0 AND gTisch_8_RFID_Write[5] = 0 AND gTisch_8_RFID_Write[6] = 0 AND gTisch_8_RFID_Write[7] = 0 AND gTisch_8_RFID_Write[8] = 0 AND gTisch_8_RFID_Write[9] = 0 THEN
  862. gMerker_Tisch_8_alles_nullen := FALSE;
  863. gMerker_Tisch_8_RFID_Reset := FALSE;
  864. Tisch_8_RFID := 0;
  865. END_IF
  866. END_CASE
  867. OPCUA_TEST_1;
  868. OPCUATEST2;
  869. OPCUATEST3;
  870. END_PROGRAM
  871. PROGRAM _EXIT
  872. (* Insert code here *)
  873. END_PROGRAM