Rezepturen verwenden
Rezepturverwalter hinzufügen
Selektieren Sie im Gerätebaum das Objekt Applikation.
Für eine Applikation kann nur ein Rezepturverwalter hinzugefügt werden.
Wählen Sie den Befehl Projekt → Objekt hinzufügen → Rezepturverwalter.
Der Rezepturverwalter wird zum Gerätebaum hinzugefügt.
Rezepturdefinition hinzufügen
Voraussetzung: Ein Rezepturverwalter ist in der Applikation vorhanden.
Selektieren Sie im Gerätebaum das Objekt Rezepturverwalter.
Wählen Sie den Befehl Projekt → Objekt hinzufügen → Rezepturdefinition.
Die Rezepturdefinition wird unterhalb des Rezepturverwalters hinzugefügt.
Es können zu einem Rezepturverwalter beliebig viele Rezepturdefinieitonen hinzugefügt werden.
Speicherort festlegen
Legt den Ablageort zum Lesen und Schreiben von Rezepturdateien fest.
Hinweis
Die Pfadkonfiguration kann je nach verwendeter SPS unterschiedlich ausfallen.
Bei CODESYS Control Win SL müssen relative Pfade, die auf ein Verzeichnis im SPS‑Dateisystem (PlcLogic) verweisen, immer mit ./ beginnen. Andernfalls kann es zu unerwartetem Verhalten kommen, da Rezepturdateinamen in der Regel einfach an den konfigurierten Speicherort angehängt werden.
Voraussetzung: Ein Rezepturverwalter ist in der Applikation vorhanden.
Öffnen Sie im Gerätebaum das Objekt Rezepturverwalter.
Öffnen Sie im Objekt Rezepturverwalter die Registerkarte Speicherung.
Legen Sie den gewünschten Pfad im Feld Dateipfad fest oder verwenden Sie den Explorer über die Schaltfläche
.
Verwenden Sie die Methode RecipeManCommands.SetStoragePath (METH).
Mit dieser Methode kann der Speicherpfad zur Laufzeit aktualisiert werden, um beispielsweise Rezepturdateien unterschiedlichen Verzeichnissen zuzuordnen.
Variablen zu einer Rezepturdefinition hinzufügen
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition durch einen Doppelklick auf das Objekt.
Führen Sie einen Doppelklick im Editor auf das leere Feld unterhalb Variable aus. Geben Sie den Namen einer Variablen an, für die Sie eine Rezeptur definieren wollen. Die Eingabehilfe steht dazu bereit: Schaltfläche
.Voraussetzung: Die Variablen müssen im Deklarationseditor des Programms oder der
GVLdeklariert sein.Fügen Sie bei Bedarf weitere Variablen ein.
Die Werte einer Variable können für jede Rezeptur separat festgelegt werden.
Eine neue, leere Rezeptur hinzufügen
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition durch einen Doppelklick auf das Objekt.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der Tabelle.
Wählen Sie die Option Rezeptur einfügen.
Vergeben Sie einen eindeutigen Namen und bestätigen Sie mit OK.
Verwenden Sie die Methode RecipeManCommands.CreateRecipeNoSave (METH), um eine leere Rezeptur zu erzeugen, ohne weitere Aktionen auszuführen.
Der Suffix
NoSaveverhindert, dass eine Rezepturdatei am aktuell definierten Speicherort angelegt wird.Hinweis
Eine Rezeptur wird nach ihrer Erstellung nur dann automatisch in eine Rezepturdatei gespeichert, wenn im Objekt Rezepturverwalter in der Registerkarte Allgemein die Option Rezepturänderungen automatisch in Rezepturdateien speichern aktiviert ist.
Eine Rezepturdatei speichern
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition, welche die Rezeptur enthält, die in eine Rezepturdatei exportiert werden soll.
Geben Sie unter der Rezeptur den Wert der Variablen für diese Rezeptur an.
Klicken Sie mit der rechten Maustaste auf eine beliebige Zelle in der Rezepturspalte der zu speichernden Rezeptur.
Wählen Sie die Option Rezeptur speichern....
Verwenden Sie das Explorer‑Fenster, um den gewünschten Speicherort und Dateinamen zu vergeben.
Verwenden Sie die Methode RecipeManCommands.SaveRecipe (METH).
Eine neue Rezeptur hinzufügen, die aktuelle SPS-Werte enthält
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition durch einen Doppelklick auf das Objekt.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der Tabelle.
Wählen Sie die Option Rezeptur einfügen und bestätigen Sie mit OK.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der Rezepturspalte der neu erzeugten Rezeptur.
Das Programmiersystem muss online mit der SPS verbunden sein. Wählen Sie im Kontextmenü die Option Rezeptur lesen, um aktuellen SPS‑Variable auszulesen und in die Rezeptur zu übernehmen.
Verwenden Sie die Methode RecipeManCommands.CreateRecipe (METH).
Diese Funktion erzeugt eine neue Rezeptur im Puffer und liest anschließend automatisch die aktuellen SPS‑Variablen ein.
Hinweis
Wenn im Objekt Rezepturverwalter in der Registerkarte Allgemein die Option Rezepturänderungen automatisch in Rezepturdateien speichern aktiviert ist, dann wird die Rezeptur zusätzlich automatisch in eine Rezepturdatei gespeichert.
Eine Rezeptur aus dem Dateisystem in den Puffer laden
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition, für die die Rezeptur geladen werden soll.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der Tabelle.
Wählen Sie die Option Rezeptur einfügen und bestätigen Sie mit OK.
Eine neue Rezeptur mit dem angegebenen Namen erscheint auf der rechten Seite der Tabelle.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der eingefügten Rezeptur.
Wählen Sie die Option Rezeptur laden... und bestätigen Sie mit OK.
Verwenden Sie das Explorer‑Fenster, um die gewünschte Rezepturdatei zu suchen und auszuwählen.
Die Daten werden angezeigt.
Verwenden Sie die Methode RecipeManCommands.LoadRecipe (METH).
Rezeptur aus einer Datei laden
Voraussetzung: In der Applikation gibt es eine Rezepturverwaltung. In einer Rezepturdefinition gibt es eine Rezeptur myRec mit Variablenwerten. Eine Rezepturdatei myRec.txt, die Einträge für diese Rezeptur enthält, liegt im Dateisystem vor.
Beispiel der Rezepturdatei:
PLC_PRG.bVar:=0 PLC_PRG.iVar:=2 PLC_PRG.dwVar:=35232 PLC_PRG.stVar:='first' PLC_PRG.wstVar:='123443245'
Öffnen Sie mit Doppelklick auf das Objekt Rezepturdefinition im Gerätebaum den Tabelleneditor für die Definition der einzelnen Rezepturen.
Sie sehen eine Spalte
myRecmit den aktuellen Werte für diese Rezeptur.Bearbeiten Sie die Datei
myRec.txtin einem externen Texteditor und ersetzen die Variablenwerte durch andere, die Sie in die Rezepturdefinition in CODESYS laden möchten. Speichern Sie die Datei.Klicken Sie in der Rezepturdefinition in die Spalte von myRec und wählen im Kontextmenü den Befehl Rezeptur laden....
Ein Hinweis auf die mögliche Notwendigkeit eines Online-Changes beim nächsten Einloggen erscheint. Ein Online-Change wird nötig, falls Sie durch das Laden der Rezeptur die aktuellen Werte der Rezepturvariablen verändern.
Schließen Sie den Hinweisdialog mit Ja (Fortfahren). Wählen Sie die Datei
myRec.txtaus dem Datei-Explorer zum Laden aus.Die Rezepturwerte in der Rezepturdefinition werden entsprechend den in der Datei gelesenen Werten aktualisiert.
Tipp
Wenn Sie nur einzelne Variablen der Rezeptur mit neuen Werten überschreiben möchten, entfernen Sie vor dem Laden in der Rezepturdatei die Werte für die restlichen Variablen. Einträge ohne Wertangabe werden nicht eingelesen und somit bleiben diese Variablen auf der Steuerung und im Projekt durch die Aktualisierung unberührt.
Bei Werten vom Datentyp REAL/LREAL wird in manchen Fällen auch der Hexadezimalwert in die Rezepturdatei geschrieben. Dies ist notwendig, damit bei der Rückkonvertierung der exakt identische Wert wiederhergestellt wird. In diesem Fall ändern Sie den Dezimalwert und löschen den Hexadezimalwert.
SPS‑Werte in eine gepufferte Rezeptur einlesen
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Aktuelle SPS‑Variablenwerte werden in eine gepufferte Rezeptur eingelesen.
Öffnen Sie den Editor der Rezepturdefinition, die die Rezeptur enthält, in welche die SPS‑Variablen eingelesen werden sollen.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle in der Rezepturspalte der Rezeptur.
Wählen Sie die Option Rezeptur lesen. Diese Option ist nur im Onlinebetrieb der Applikation verfügbar.
Verwenden Sie die Methode RecipeManCommands.ReadRecipe(METH).
Rezepturwerte aus einer Rezepturdatei in SPS‑Variablen schreiben
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Diese Funktion lädt Werte aus einer Rezepturdatei in eine bereits vorhandene gepufferte Rezeptur und schreibt diese anschließend in die zugeordneten SPS‑Variablen.
Öffnen Sie den Editor der Rezepturdefinition, die die Rezeptur enthält, aus der die Werte in die SPS‑Variablen geschrieben werden sollen.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle in der Rezepturspalte der Rezeptur, die in die SPS geschrieben werden soll.
Wählen Sie die Option Rezeptur laden und schreiben.... Diese Option ist nur im Onlinebetrieb der Applikation verfügbar.
Verwenden Sie die Methode RecipeManCommands.LoadAndWriteRecipe(METH).
Rezepturwerte aus einer gepufferten Rezeptur in SPS‑Variablen schreiben
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition, die die Rezeptur enthält, aus der die Werte in die SPS‑Variablen geschrieben werden sollen.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle in der Rezepturspalte der Rezeptur, die in die SPS geschrieben werden soll.
Wählen Sie die Option Rezeptur schreiben. Diese Option ist nur im Onlinebetrieb der Applikation verfügbar.
Verwenden Sie die Methode RecipeManCommands.WriteRecipe(METH).
SPS‑Werte in eine gepufferte Rezeptur einlesen und in eine Rezepturdatei exportieren
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie den Editor der Rezepturdefinition, die die Rezeptur enthält, welche zum Einlesen der SPS‑Variablen verwendet werden soll und anschließend in eine Rezepturdatei geschrieben wird.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle in der Rezepturspalte der gewünschten Rezeptur.
Wählen Sie die Option Rezeptur lesen und speichern… und bestätigen Sie im folgenden Dialog Ihre gewünschte Online-Change-Option mit OK.
Wählen Sie einen Speicherort und einen Dateinamen und klicken Sie Speichern.
Verwenden Sie die Methode RecipeManCommands.ReadAndSaveRecipe(METH).
Rezepturwerte von der Steuerung laden
Sie können Rezepturwerte, die auf dem Steuerungsgerät vorliegen, in die im Projekt vorliegenden Rezepturdefinitionen übernehmen, auch wenn diese Definitionen im Projekt mittlerweile erweitert wurden.
Voraussetzung: Die Option Rezepturverwaltung in der SPS im Rezepturverwalter ist aktiviert.
Erstellen Sie im Projekt eine Rezepturdefinition
RecDef1, die die VariablenPLC_PRG.ivarundPLC_PRG.bvarenthält. Fügen Sie eine Rezeptur R1 ein: Wert fürPLC_PRG.ivar:33, Wert fürPLC_PRG.bvar:TRUE.Loggen Sie auf die Steuerung ein und laden Sie die Applikation.
Die Rezepturdatei
R1.RecDef1.txtrecipewird im Standardverzeichnis der Steuerung ($PlcLogic$) abgelegt.Loggen Sie wieder aus und fügen Sie in der Rezepturdefinition im Projekt eine weitere Variable hinzu:
PLC_PRG.dwvar.Editieren Sie die Rezepturdefinitionsdatei
R1.RecDef1.txtrecipeauf dem Gerät und ändern Sie den Wert fürPLC_PRG.ivarvon33auf34.Fügen Sie außerdem auf dem Gerät eine weitere Rezeptur R2 hinzu. Dazu kopieren Sie die Datei
R1.RecDef1.txtrecipeund benennen sie um inR2.RecDef1.txtrecipe. Dann editieren Sie diese Datei und ändern die Rezepturwerte:PLC_PRG.ivar:1,PLC_PRG.bvar:FALSE.Nun liegen auf dem Gerät zwei Rezepturen R1 und R2 bereit. Im Projekt gibt es nur R1 und sie enthält außerdem andere Werte als R1 auf dem Gerät..
Loggen Sie mit Online-Change wieder auf die Steuerung ein.
Wählen Sie den Befehl Rezepturen vom Gerät laden aus dem Kontextmenü.
Eine Meldungsbox informiert, dass das Ausführen des Befehls beim nächsten Einloggen einen Online-Change auslösen kann, und dass die Rezepturen der aktuellen Rezepturdefinition mit den Rezepturen aus dem Laufzeitsystem überschrieben werden.
Bestätigen Sie, dass Sie fortfahren wollen.
Eine Meldungsbox informiert, dass die vom Gerät geladene Rezeptur für
PLC_PRG.dwvarkeinen Wert aus der Steuerung liefern kann.Bestätigen Sie, dass Sie fortfahren wollen.
Der Wert von
PLC_PRG.ivarin Rezeptur R1 in der Rezepturdefinition im Projekt ändert sich auf34. Die Rezeptur R2 mit den Werten1undFALSEerscheint nun ebenfalls in der Rezepturdefinition.PLC_PRG.dwvarbleibt in der Rezepturdefinition.
Eine Rezeptur löschen
Voraussetzung: Ein Rezepturverwalter mit einer Rezepturdefinition ist in der Applikation vorhanden.
Öffnen Sie die Rezepturdefinition, aus der eine Rezeptur gelöscht werden soll.
Klicken Sie mit der rechten Maustaste in eine beliebige Zelle der Rezepturspalte der zu entfernenden Rezeptur.
Wählen Sie die Option Rezeptur entfernen.
Verwenden Sie die Methode RecipeManCommands.DeleteRecipe (METH).