Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. MAX! Cube Blockly Abwesenheit

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    MAX! Cube Blockly Abwesenheit

    This topic has been deleted. Only users with topic management privileges can see it.
    • Marko1974
      Marko1974 @mickym last edited by

      @mickym said in MAX! Cube Blockly Abwesenheit:

      @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

      @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

      @marko1974 was ich vielleicht gerne noch hätte ist, dass Telegram die Datenpunkte der verschiedenen Räume mit ausschmeisst.
      Also dass man quasi sehen kann, wenn man draussen ist auf welche Temperaturen sie nun gestellt werden, aber nur wenn An- oder Abwesenheit sich ändern.
      Nicht wenn das Auto Programm abläuft und man ist zuhause

      Meine Fragen interessieren Dich eigentlich nicht, Du denkst schon wieder über weiter Features nach????

      Das stimmt nicht und ist nur immer Dein Eindruck

      Na ich bin mir immer noch nicht sicher, ob Du die split Node begriffen hast und was ein Javascript Objekt ist und es ist richtig, dass die ECO Temperatur tatsächlich immer ausgelesen wird, aber nachdem er dann ausgelsen wurde, wie wird er dann im Flow weiter verarbeitet? Und trotzdem würdest Du gerne noch eine telegramm Nachricht bekommen .

      Nach rbe und entprellen ist bei mir Feierabend.....

      mickym 1 Reply Last reply Reply Quote 0
      • mickym
        mickym Most Active @Marko1974 last edited by

        @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

        @mickym said in MAX! Cube Blockly Abwesenheit:

        @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

        @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

        @marko1974 was ich vielleicht gerne noch hätte ist, dass Telegram die Datenpunkte der verschiedenen Räume mit ausschmeisst.
        Also dass man quasi sehen kann, wenn man draussen ist auf welche Temperaturen sie nun gestellt werden, aber nur wenn An- oder Abwesenheit sich ändern.
        Nicht wenn das Auto Programm abläuft und man ist zuhause

        Meine Fragen interessieren Dich eigentlich nicht, Du denkst schon wieder über weiter Features nach????

        Das stimmt nicht und ist nur immer Dein Eindruck

        Na ich bin mir immer noch nicht sicher, ob Du die split Node begriffen hast und was ein Javascript Objekt ist und es ist richtig, dass die ECO Temperatur tatsächlich immer ausgelesen wird, aber nachdem er dann ausgelsen wurde, wie wird er dann im Flow weiter verarbeitet?

        Nunja....Node-Red funktioniert halt so, dass es Nachrichten durch die einzelnen Nodes schickt. Die Nachrichten sind Javascript objekte die einen bestimmten Typ haben können. z.b. Number, string oder boolean (also true or false). Die haben alle ne ID und können so auch getracked werden.
        Der einfachste Weg zu sehen was gesendet wird ist die Debug node. Die kann ich halt auch so setten, dass ich nur bestimmte Dinge sehen möchte. Standardmäßig zeigt die erstmal den ganzen payload an. Interessant ist aber auch was in Object oder sonstigen unterpunkten passiert.

        Die Nachrichten sind Javascript objekte die einen bestimmten Typ haben können. z.b. Number, string oder boolean (also true or false).

        Das ist falsch - das wesentliche eines Javascript Objektes ist, dass es meist mehrere Eigenschaften besitzt, die skalare Werte (wie strings etc.) enthalten können aber auch weitere Objekte.

        f0cecb25-7287-4147-9fea-811dabc24583-image.png

        Aus dieser Webseite - hier mal die Person - als ein Objekt.

        0add1886-9679-4c72-8757-86ed092e8569-image.png b5d52e78-2cb6-4e31-baae-63bc3d1a1c15-image.png

        Und wie auf die Eingeschaften auf diese Objekte zugreifst.

        Siehst Du Ähnlichkeiten mit dem JS Objekt in den Change Nodes?

        e6791bcc-13d2-44b1-92b9-c28f9fad7790-image.png

        Marko1974 1 Reply Last reply Reply Quote 0
        • mickym
          mickym Most Active @Marko1974 last edited by

          @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

          @mickym said in MAX! Cube Blockly Abwesenheit:

          @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

          @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

          @marko1974 was ich vielleicht gerne noch hätte ist, dass Telegram die Datenpunkte der verschiedenen Räume mit ausschmeisst.
          Also dass man quasi sehen kann, wenn man draussen ist auf welche Temperaturen sie nun gestellt werden, aber nur wenn An- oder Abwesenheit sich ändern.
          Nicht wenn das Auto Programm abläuft und man ist zuhause

          Meine Fragen interessieren Dich eigentlich nicht, Du denkst schon wieder über weiter Features nach????

          Das stimmt nicht und ist nur immer Dein Eindruck

          Na ich bin mir immer noch nicht sicher, ob Du die split Node begriffen hast und was ein Javascript Objekt ist und es ist richtig, dass die ECO Temperatur tatsächlich immer ausgelesen wird, aber nachdem er dann ausgelsen wurde, wie wird er dann im Flow weiter verarbeitet? Und trotzdem würdest Du gerne noch eine telegramm Nachricht bekommen .

          Nach rbe und entprellen ist bei mir Feierabend.....

          Welche Node genau in dem Flow liest den ECO Wert aus dem Datenpunkt und wie?

          Tipp - rbe und entprellen sind viel weiter hinten - und aus dem Feierabend wollen wir doch ein erhellendes Aufwachen am Morgen machen, oder?

          1 Reply Last reply Reply Quote 0
          • mickym
            mickym Most Active @Marko1974 last edited by

            @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

            Zumindest kenne ich nun schon Inject, change, iobroker out, split und auch debug nodes ...wie man die debugs intgriert, wie man sie an und ausmacht und wo die nachrichten ankommen....und dass man auch mal trocken üben kann.
            Willst Du mir jetzt wirklich noch unterstellen, ich sei nicht lernfähig oder hab da keinen Bock drauf?
            Ich bau doch sogar in blockly nach. Ja....teilweise war es kopiert, aber die Inhalte hab ich geändert....und genau dann weiss ich doch auch wie es funktioniert, oder? Wenn ich es mit meinen anderen Dingen nachbaue.
            Das Fenster habe ich immer noch nicht fertig drin....

            Na die split Node hast noch nicht richtig erklärt - mache ich in meinem nächsten Post. Wenn Du die Inject Node so halbwegs begriffen hast und den Unterschied, ob Du in den debug Nodes nur die payload oder das ganze Nachrichtenobjekt ausgibst - also das Javascript Objekt - dann weißt Du schon mal was zu den Grundlagen, auf den wir weiter aufbauen.

            Marko1974 1 Reply Last reply Reply Quote 0
            • Marko1974
              Marko1974 @mickym last edited by

              @mickym said in MAX! Cube Blockly Abwesenheit:

              @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

              @mickym said in MAX! Cube Blockly Abwesenheit:

              @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

              @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

              @marko1974 was ich vielleicht gerne noch hätte ist, dass Telegram die Datenpunkte der verschiedenen Räume mit ausschmeisst.
              Also dass man quasi sehen kann, wenn man draussen ist auf welche Temperaturen sie nun gestellt werden, aber nur wenn An- oder Abwesenheit sich ändern.
              Nicht wenn das Auto Programm abläuft und man ist zuhause

              Meine Fragen interessieren Dich eigentlich nicht, Du denkst schon wieder über weiter Features nach????

              Das stimmt nicht und ist nur immer Dein Eindruck

              Na ich bin mir immer noch nicht sicher, ob Du die split Node begriffen hast und was ein Javascript Objekt ist und es ist richtig, dass die ECO Temperatur tatsächlich immer ausgelesen wird, aber nachdem er dann ausgelsen wurde, wie wird er dann im Flow weiter verarbeitet?

              Nunja....Node-Red funktioniert halt so, dass es Nachrichten durch die einzelnen Nodes schickt. Die Nachrichten sind Javascript objekte die einen bestimmten Typ haben können. z.b. Number, string oder boolean (also true or false). Die haben alle ne ID und können so auch getracked werden.
              Der einfachste Weg zu sehen was gesendet wird ist die Debug node. Die kann ich halt auch so setten, dass ich nur bestimmte Dinge sehen möchte. Standardmäßig zeigt die erstmal den ganzen payload an. Interessant ist aber auch was in Object oder sonstigen unterpunkten passiert.

              Die Nachrichten sind Javascript objekte die einen bestimmten Typ haben können. z.b. Number, string oder boolean (also true or false).

              Das ist falsch - das wesentliche eines Javascript Objektes ist, dass es meist mehrere Eigenschaften besitzt, die skalare Werte (wie strings etc.) enthalten können aber auch weitere Objekte.

              f0cecb25-7287-4147-9fea-811dabc24583-image.png

              Aus dieser Webseite - hier mal die Person - als ein Objekt.

              0add1886-9679-4c72-8757-86ed092e8569-image.png b5d52e78-2cb6-4e31-baae-63bc3d1a1c15-image.png

              Und wie auf die Eingeschaften auf diese Objekte zugreifst.

              Siehst Du Ähnlichkeiten mit dem JS Objekt in den Change Nodes?

              e6791bcc-13d2-44b1-92b9-c28f9fad7790-image.png

              Ja die Heizung ist das eigentliche Objekt und die kann halt mehrere Eigenschaften haben.

              Dann muesste ja auch gehen:

              const heizung = {
              name :  "Schlafzimmerthermo xyz",
              mode: AUTO
              setpointtemperature: 20
              };
              
              
              mickym 1 Reply Last reply Reply Quote 0
              • Marko1974
                Marko1974 @mickym last edited by

                @mickym said in MAX! Cube Blockly Abwesenheit:

                @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                Zumindest kenne ich nun schon Inject, change, iobroker out, split und auch debug nodes ...wie man die debugs intgriert, wie man sie an und ausmacht und wo die nachrichten ankommen....und dass man auch mal trocken üben kann.
                Willst Du mir jetzt wirklich noch unterstellen, ich sei nicht lernfähig oder hab da keinen Bock drauf?
                Ich bau doch sogar in blockly nach. Ja....teilweise war es kopiert, aber die Inhalte hab ich geändert....und genau dann weiss ich doch auch wie es funktioniert, oder? Wenn ich es mit meinen anderen Dingen nachbaue.
                Das Fenster habe ich immer noch nicht fertig drin....

                Na die split Node hast noch nicht richtig erklärt - mache ich in meinem nächsten Post. Wenn Du die Inject Node so halbwegs begriffen hast und den Unterschied, ob Du in den debug Nodes nur die payload oder das ganze Nachrichtenobjekt ausgibst - also das Javascript Objekt - dann weißt Du schon mal was zu den Grundlagen, auf den wir weiter aufbauen.

                Nein ich gebe immer das ganze Objekt aus, denn wie gerade mal wieder gelernt hat das JS Objekt mehrere Eigenschaften und die kann ich ja dann aufklappen.

                Marko1974 1 Reply Last reply Reply Quote 0
                • Marko1974
                  Marko1974 @Marko1974 last edited by

                  @marko1974 kann ich nicht einfach ein injectnode mit get desiredtemperature nehmen?

                  Marko1974 1 Reply Last reply Reply Quote 0
                  • Marko1974
                    Marko1974 @Marko1974 last edited by

                    @marko1974 said in MAX! Cube Blockly Abwesenheit:

                    @marko1974 kann ich nicht einfach ein injectnode mit get desiredtemperature nehmen?

                    nee das geht nicht...das ist quatsch

                    Marko1974 1 Reply Last reply Reply Quote 0
                    • Marko1974
                      Marko1974 @Marko1974 last edited by Marko1974

                      @mickym

                      ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                      ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                      mickym Marko1974 2 Replies Last reply Reply Quote 0
                      • mickym
                        mickym Most Active @Marko1974 last edited by

                        @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                        Ja die Heizung ist das eigentliche Objekt und die kann halt mehrere Eigenschaften haben.
                        Dann muesste ja auch gehen:

                        > const heizung = {
                        > name :  "Schlafzimmerthermo xyz",
                        > mode: AUTO
                        > setpointtemperature: 20
                        > };
                        

                        Richtig müsste es also wie folgt aussehen:

                        > const heizung = {
                        > name :  "Schlafzimmerthermo xyz",
                        > mode: "AUTO",
                        > setpointtemperature: 20
                        > };
                        

                        Grundsätzlich ja - wenn Du in Javascript programmieren würdest.
                        Zugreifen würdest Du dann auf die Eigenschaften mit

                        var name= heizung.name;
                        var desiredTemperature = heizung.setpointtemperature
                        

                        Die Variable name würde dann den String "Schlafzimmerthermo xyz" enthalten.
                        Du würdest noch einen Fehler bekommen, weil Du das Komma hinter AUTO vergessen hast, das die Eigenschaften voneinander abgrenzt und AUTO ein String ist, der immer in Anführungszeichen stehen muss

                        in Node Red definierst Du ein Objekt zum Beispiel in Inject-Nodes oder ChangeNodes - wenn Du beide geschweiften Klammern siehst - das weisst man also nicht einer Variablen zu, sondern wieder einer Eigenschaft des Nachrichtenobjektes.

                        94e8c9ee-3227-4f0e-a32f-ef682d239161-image.png

                        Um Dein Beispiel zu nehmen - was Du im Javascript gemacht hast und es einem Objekt namens heizung zugewiesen hast - sieht dann in einer InjectNode, wie folgt aus:

                        Wenn Du also Deine Definition im JSON Editor einer Inject Node reinkopierst - bekommst Du Fehler - weil das Objekt wie oben beschrieben Syntaxfehler hast. Fährst Du mit der Maus über den Fehler bekommst Du eine Fehlermeldung, die Dir Hinweise geben:

                        dc67b491-63bd-4694-8d80-f3f0880210a2-image.png

                        Das Problem ist, dass Du die Objekteigenschaften nicht als Objekt direkt eingibst, sondern als JSON String. Deshalb müssen die Eigenschaften auch in "Anführungszeichen" setzen muss.

                        So würde also Deine Objektdefinition im NodeRed als JSON String aussehen:

                        97cc1b8e-8897-44fd-93a8-78e9691584aa-image.png

                        dieses Objekt weisen wir also dem Objekt heizung zu und da in Node Red nur msg Objekt durch die Kabel laufen - ist das Objekt Heizung wiederum eine Eigenschaft des msg Objektes.

                        51d8bdd3-a8fb-464a-aa78-3efc0f000d0b-image.png

                        Nun lassen wir uns das ganze Javascript Object msg in der Debug Node ausgeben - indem wir das in der Debug Node so bestimmen:
                        47dc6bc8-1459-4ccc-9daa-46c0e07ab405-image.png

                        Führen wir diesen Flow aus - und klappen im msg.objekt - das objekt heizung auf

                        da93fca9-7232-4cdc-96ac-d2291fd5b9c0-image.png

                        siehst Du alle Eigenschaften Deines Objektes.

                        1 Reply Last reply Reply Quote 0
                        • mickym
                          mickym Most Active @Marko1974 last edited by

                          @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                          @mickym

                          ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                          ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                          Super !!! - Genau so ist - die Inject Node kannst wegschmeissen - die habe ich nur gebraucht - weil ich ja keinen MaxCube Adapter habe.

                          wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.

                          Nur wie kommt das OK des duty Cycle in den Hauptflow?

                          In diesem Fall wird die flow Variable dutyCycleOK auf true oder false gesetzt und dann unten in dem Flow abgefragt. Das ist nötig, da die Ereignisse ja nicht gleichzeitig an der selben Node ankommen.
                          Deswegen wird die flowVariable zeitlich unabhängig vom eigentlichen Flow gesetzt.

                          5fff9103-2f30-445b-ba18-ef9e48941c3d-image.png

                          In der switch Node wird der Inhalt der flowVariablen abgefragt und dann der Flow entweder blockiert oder durchgelassen.

                          Die wichtigen Dinge markiere ich Dir immer farbig:

                          420e0f4c-34a4-46d7-a908-34f441e15c81-image.png

                          Du kannst Dir den Inhalt Deiner Kontextdaten wie folgt anschauen:

                          6d5ec0ee-1588-4f25-b7d6-d18b23559b23-image.png

                          Im Kontextfenster siehst Du dann den Inhalt der Kontextvariablen - in diesem Fall der Flowvariable dutyCycleOK

                          2fabce2c-d93b-41ba-b01d-fafea6a41776-image.png

                          hier musst Du aber immer manuell aktualisieren

                          8fea593e-43e5-4105-a768-3fecd0fa5e00-image.png

                          mickym Marko1974 2 Replies Last reply Reply Quote 0
                          • Marko1974
                            Marko1974 @Marko1974 last edited by

                            @marko1974 Ich glaube ich habe gerade helle Momente:

                            Der Trigger fragt ab ob die Heizungssteuerung aktiv ist. Da wollten wir eventuell noch was vorbauen, also ist die erstmal IMMER aktiv jetzt.
                            Dann erstellst Du die Räume Kinderzimmer, Schlafzimmer etc.
                            mit topic setzen holt man sich quasi alle daten aus unseren erstellten DP in userdata0.heizung....keinen bestimmten, sondern alle. Nee die holt man sich nicht, sondern man setzt sie quasi als ein "Oberthema?" im nächsten Schritt in get mode im ioBroker in braucht man dann quasi nur nach mode zu fragen und muss den Datenpunkt nicht wählen, da man im Schritt davor quasi schon den Pfad bereitgestellt hat. So auch mit der Temperatur und auch der ecotemperatur
                            Neben den Räumen gibt es dann die Heizungen.....warum die als Eigenschaft msg.room haben weiss ich noch nicht. Zumindest zählt man dann auf welche heizungen es gibt.

                            Im nächsten Schritt setzen wir den Mode für jede Heizung der den Entweder unser Auto Profil sein kann, oder aber auch ECO, HEAT oder OFF. Off wird hier direkt eine Temperatur zugewiesen. Heat bekommt desiredTemperature als payload gesetzt und eco die eco_temperature. rbe hält was auf falls die alle unentwegt was senden. Entprellen sagtest Du ist was, dass es etwas verlangsamt wird, bevor es an den adapter punkt gesendet wird. Ob da nochmal ne Verzögerung rein muss darüber lässt sich streiten...und wenn dann noch der Duty cycle ok ist...als kleiner oder gleich 85 senden die Heizungen also der room an die DP direkt.

                            WIE WAR ICH?

                            mickym 1 Reply Last reply Reply Quote 0
                            • mickym
                              mickym Most Active @mickym last edited by

                              @mickym So ich wollte mit der Theorie fortfahren, aber erst mal auf Dein Vorpost eingehen - Du wirst langsam immer besser - und nun beginnt es mir wieder etwas Spaß zu machen die Dinge zu erklären. Ich hoffe Du führst Dir auch meine Ausführungen zu dem JS und msg Objekt aus meinem vorangegangen Post zur Gemüte und fragst, wenn was unklar ist. Das ist mir wichtiger als der Flow - weil die Grundlagen musst Du verstehen, wenn Du den Flow verstehen willst. - Wie auch was eine Flowvariable etc. ist.

                              Marko1974 2 Replies Last reply Reply Quote 0
                              • Marko1974
                                Marko1974 @mickym last edited by

                                @mickym sind Quelle und Was ist zu tun nicht eigentlich nur ne Hilfestelllung für den besseren Überblick?

                                mickym 1 Reply Last reply Reply Quote 0
                                • Marko1974
                                  Marko1974 @mickym last edited by

                                  @mickym said in MAX! Cube Blockly Abwesenheit:

                                  @mickym So ich wollte mit der Theorie fortfahren, aber erst mal auf Dein Vorpost eingehen - Du wirst langsam immer besser - und nun beginnt es mir wieder etwas Spaß zu machen die Dinge zu erklären. Ich hoffe Du führst Dir auch meine Ausführungen zu dem JS und msg Objekt aus meinem vorangegangen Post zur Gemüte und fragst, wenn was unklar ist. Das ist mir wichtiger als der Flow - weil die Grundlagen musst Du verstehen, wenn Du den Flow verstehen willst. - Wie auch was eine Flowvariable etc. ist.

                                  Nee bei Flowvariablen bin ich noch nicht... 🙂

                                  1 Reply Last reply Reply Quote 0
                                  • Marko1974
                                    Marko1974 @mickym last edited by

                                    @mickym said in MAX! Cube Blockly Abwesenheit:

                                    @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                    @mickym

                                    ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                                    ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                                    Super !!! - Genau so ist - die Inject Node kannst wegschmeissen - die habe ich nur gebraucht - weil ich ja keinen MaxCube Adapter habe.

                                    wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.

                                    Nur wie kommt das OK des duty Cycle in den Hauptflow?

                                    In diesem Fall wird die flow Variable dutyCycleOK auf true oder false gesetzt und dann unten in dem Flow abgefragt. Das ist nötig, da die Ereignisse ja nicht gleichzeitig an der selben Node ankommen.
                                    Deswegen wird die flowVariable zeitlich unabhängig vom eigentlichen Flow gesetzt.

                                    Dachte eigentlich weil der duty cycle check unabhängig vom restflow ist und quasi obendrüber gesetzt wird, sendet er ein okay in den flow, was dann unten abgefragt wird.

                                    5fff9103-2f30-445b-ba18-ef9e48941c3d-image.png

                                    In der switch Node wird der Inhalt der flowVariablen abgefragt und dann der Flow entweder blockiert oder durchgelassen.

                                    Die wichtigen Dinge markiere ich Dir immer farbig:

                                    420e0f4c-34a4-46d7-a908-34f441e15c81-image.png

                                    Du kannst Dir den Inhalt Deiner Kontextdaten wie folgt anschauen:

                                    6d5ec0ee-1588-4f25-b7d6-d18b23559b23-image.png

                                    Im Kontextfenster siehst Du dann den Inhalt der Kontextvariablen - in diesem Fall der Flowvariable dutyCycleOK

                                    2fabce2c-d93b-41ba-b01d-fafea6a41776-image.png

                                    hier musst Du aber immer manuell aktualisieren

                                    8fea593e-43e5-4105-a768-3fecd0fa5e00-image.png

                                    Marko1974 1 Reply Last reply Reply Quote 0
                                    • Marko1974
                                      Marko1974 @Marko1974 last edited by

                                      @marko1974 said in MAX! Cube Blockly Abwesenheit:

                                      @mickym said in MAX! Cube Blockly Abwesenheit:

                                      @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                      @mickym

                                      ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                                      ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                                      Super !!! - Genau so ist - die Inject Node kannst wegschmeissen - die habe ich nur gebraucht - weil ich ja keinen MaxCube Adapter habe.

                                      wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.

                                      Nur wie kommt das OK des duty Cycle in den Hauptflow?

                                      In diesem Fall wird die flow Variable dutyCycleOK auf true oder false gesetzt und dann unten in dem Flow abgefragt. Das ist nötig, da die Ereignisse ja nicht gleichzeitig an der selben Node ankommen.
                                      Deswegen wird die flowVariable zeitlich unabhängig vom eigentlichen Flow gesetzt.

                                      Dachte eigentlich weil der duty cycle check unabhängig vom restflow ist und quasi obendrüber gesetzt wird, sendet er ein okay in den flow, was dann unten abgefragt wird.

                                      5fff9103-2f30-445b-ba18-ef9e48941c3d-image.png

                                      In der switch Node wird der Inhalt der flowVariablen abgefragt und dann der Flow entweder blockiert oder durchgelassen.

                                      Das hab ich aber doch auch so geschildert.
                                      Jetzt nicht mit fremden Federn schmücken, bitte 🙂

                                      Die wichtigen Dinge markiere ich Dir immer farbig:

                                      420e0f4c-34a4-46d7-a908-34f441e15c81-image.png

                                      Du kannst Dir den Inhalt Deiner Kontextdaten wie folgt anschauen:

                                      6d5ec0ee-1588-4f25-b7d6-d18b23559b23-image.png

                                      Im Kontextfenster siehst Du dann den Inhalt der Kontextvariablen - in diesem Fall der Flowvariable dutyCycleOK

                                      2fabce2c-d93b-41ba-b01d-fafea6a41776-image.png

                                      hier musst Du aber immer manuell aktualisieren

                                      8fea593e-43e5-4105-a768-3fecd0fa5e00-image.png

                                      Marko1974 1 Reply Last reply Reply Quote 0
                                      • Marko1974
                                        Marko1974 @Marko1974 last edited by Marko1974

                                        @marko1974 said in MAX! Cube Blockly Abwesenheit:

                                        @marko1974 said in MAX! Cube Blockly Abwesenheit:

                                        @mickym said in MAX! Cube Blockly Abwesenheit:

                                        @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                        @mickym

                                        ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                                        ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                                        Super !!! - Genau so ist - die Inject Node kannst wegschmeissen - die habe ich nur gebraucht - weil ich ja keinen MaxCube Adapter habe.

                                        wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.

                                        Nur wie kommt das OK des duty Cycle in den Hauptflow?

                                        In diesem Fall wird die flow Variable dutyCycleOK auf true oder false gesetzt und dann unten in dem Flow abgefragt. Das ist nötig, da die Ereignisse ja nicht gleichzeitig an der selben Node ankommen.
                                        Deswegen wird die flowVariable zeitlich unabhängig vom eigentlichen Flow gesetzt.

                                        Dachte eigentlich weil der duty cycle check unabhängig vom restflow ist und quasi obendrüber gesetzt wird, sendet er ein okay in den flow, was dann unten abgefragt wird.

                                        5fff9103-2f30-445b-ba18-ef9e48941c3d-image.png

                                        In der switch Node wird der Inhalt der flowVariablen abgefragt und dann der Flow entweder blockiert oder durchgelassen.

                                        Das hab ich aber doch auch so geschildert.
                                        Jetzt nicht mit fremden Federn schmücken, bitte 🙂

                                        Die wichtigen Dinge markiere ich Dir immer farbig:

                                        420e0f4c-34a4-46d7-a908-34f441e15c81-image.png

                                        Du kannst Dir den Inhalt Deiner Kontextdaten wie folgt anschauen:

                                        6d5ec0ee-1588-4f25-b7d6-d18b23559b23-image.png

                                        Im Kontextfenster siehst Du dann den Inhalt der Kontextvariablen - in diesem Fall der Flowvariable dutyCycleOK

                                        2fabce2c-d93b-41ba-b01d-fafea6a41776-image.png

                                        hier musst Du aber immer manuell aktualisieren

                                        8fea593e-43e5-4105-a768-3fecd0fa5e00-image.png

                                        Das habe ich mir angesehen. Bestätigt mich irgendwie in der Aussage, dass diese flow dutyCycle irgendwo aus dem aktuellen flow geholt wird.
                                        Die globale Heizungssteuerung ist ja auf global auch true

                                        mickym 1 Reply Last reply Reply Quote 0
                                        • mickym
                                          mickym Most Active @Marko1974 last edited by

                                          @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                          @marko1974 Ich glaube ich habe gerade helle Momente:

                                          Der Trigger fragt ab ob die Heizungssteuerung aktiv ist. Da wollten wir eventuell noch was vorbauen, also ist die erstmal IMMER aktiv jetzt.

                                          Korrekt. Man muss nicht mehr direkt was vorbauen, sondern kann ja mit einem weiteren Flow, der beispielsweise einen anderen Datenpunkt aus dem iobroker ausliest die globale Variable gHeizungssteuerung - die wie die dutyCycleOK funktioniert aber global über alle Flows gültig ist . Das heisst man kann diese Variable aus allen Flows später ansprechen - z.Bsp auch von einem Flow mit dem Du Wetterdaten auf einer ganz anderen Seite erstellst.

                                          Dann erstellst Du die Räume Kinderzimmer, Schlafzimmer etc.

                                          Na Du musst - sorry wenn ich das sage - versuche Dich präziser auszudrücken. Ich setze in jedem der Nachrichtenobjekte (msg) mach halt einfach eine Debug Node mit dem kompletten Nachrichtenobjekt hinter so eine Node:
                                          Exakt muss es also heißen - ich definiere eine Eigenschaft rooms im Nachrichtenobjekt und setze in jeder Change Node den Wert dieser Eigenschaft:

                                          Du siehst das Nachrichtenobjekt ist noch sehr klein:

                                          377c052d-9b36-47ff-b80e-5330975e776f-image.png

                                          mit topic setzen holt man sich quasi alle daten aus unseren erstellten DP in userdata0.heizung....keinen bestimmten, sondern alle. Nee die holt man sich nicht, sondern man setzt sie quasi als ein "Oberthema?" im nächsten Schritt in get mode im ioBroker in braucht man dann quasi nur nach mode zu fragen und muss den Datenpunkt nicht wählen, da man im Schritt davor quasi schon den Pfad bereitgestellt hat. So auch mit der Temperatur und auch der ecotemperatur

                                          Genau . ich plaziere also mal die Debug Node hinter die msg.topic Node:

                                          Da alle Change Nodes mit dieser 1. set topic Node verkabelt sind - kommen durch EINMALIGES Drücken der Inject Node 6 Nachrichten aufeinmal raus:

                                          Der Topic - enthält nun also genau den Pfad zu dem Datenpunkt der ausgelesen werden soll.
                                          Das geht über String Manipulation mit JSONATA - das auch sehr mächtige Funktionen enthält - wird uns auch später noch begegnen:

                                          a7fe580e-190a-4af2-8230-9a0d3bb19693-image.png

                                          Die Stringszusammensetzung findet ja in dieser topic Node fest:

                                          b0d7c4b1-4166-4009-a3ff-d4aa5dea2b02-image.png

                                          Das große J: - zu Beginn zeigt an, dass es sich hier um eine JSONATA Funktion handelt - diese hat wohl aus welchen Grunden bei Dir beim Import Probleme gemacht - das room enthält quasi den Inhalt der msg.room Eigenschaft die in den vorangegangenen Nodes gesetzt wurde.

                                          Im nächsten Schritt setzen wir den Mode für jede Heizung der den Entweder unser Auto Profil sein kann, oder aber auch ECO, HEAT oder OFF. Off wird hier direkt eine Temperatur zugewiesen. Heat bekommt desiredTemperature als payload gesetzt und eco die eco_temperature.

                                          Na alles viel zu flapsig und nicht exakt! - Also NEIN.

                                          Auf zur nächsten Node - der 1. iobroker get Node.

                                          d54c980a-58ef-4db8-83c1-0347508cd458-image.png

                                          Wenn Du Dir wieder die Hilfe zu dieser Node anschaust, dann siehst Du das die Node diese Datenpunkte abruft, die in msg.topic stehen und davon haben wir uns ja via Debug Node überzeugt, dass dem so ist.

                                          Wichtig ist nun die Definition des Attributes.

                                          Es gibt an in welche Eigenschaft des msg.Objektes der Inhalt des ausgelesenen Datenpunktes gespeichert wird.

                                          165b0db3-e331-4569-9040-1aa39a64dad9-image.png

                                          Neben den Räumen gibt es dann die Heizungen.....warum die als Eigenschaft msg.room haben weiss ich noch nicht. Zumindest zählt man dann auf welche heizungen es gibt.

                                          Kommt später

                                          rbe hält was auf falls die alle unentwegt was senden. Entprellen sagtest Du ist was, dass es etwas verlangsamt wird, bevor es an den adapter punkt gesendet wird. Ob da nochmal ne Verzögerung rein muss darüber lässt sich streiten...und wenn dann noch der Duty cycle ok ist...als kleiner oder gleich 85 senden die Heizungen also der room an die DP direkt.

                                          WIE WAR ICH?

                                          Die beiden letzen Punkte in einem gesonderten Post.

                                          Wenn Du die von mir deaktivierte Debug Node des gesamten Nachrichtenobjektes mal kurz aktivierst - siehst Du dass alle Minuten für alle 6 Räume Nachrichten mit allen Informationen der iobroker userdata Datenpunkte enthalten sind. Hier wird also der ECO Datenpunkt in der 3. iobroker getNode ausgelesen und dann in der Eigenschaft ecoTemperature des Nachrichtenobjektes gespeichert und durch den Flow geschickt.

                                          Alle Minuten erhälst Du alle 6 Nachrichten mit allen Informationen aus den Userdatenpunkten.

                                          5e877a42-337d-4ab5-adde-e2f9271d7b93-image.png

                                          Nun siehst Du auch wo die ECO Temperatur im Flow gespeichert wird. Ändere nun die ECO Temperatur im Datenpunkt und Du wirst sehen im nächsten Minutencyclus sind die Änderungen enthalten - probier es einfach aus.

                                          1 Reply Last reply Reply Quote 0
                                          • mickym
                                            mickym Most Active @Marko1974 last edited by

                                            @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                            @marko1974 said in MAX! Cube Blockly Abwesenheit:

                                            @marko1974 said in MAX! Cube Blockly Abwesenheit:

                                            @mickym said in MAX! Cube Blockly Abwesenheit:

                                            @marko1974 sagte in MAX! Cube Blockly Abwesenheit:

                                            @mickym

                                            ach guck mal....der injectnode holt sich den dutycycle aus dem adapter, wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.
                                            ist er größer setzt er dutycycle ok auf false und es wird gar nichts aus dem flow an die heizungen gesendet. Somit läuft das nicht über - und er macht nen Logeintrag. Das hast du ganz schön gewitzt gemacht. Darunter ist noch ne inject node die den payload angibt.

                                            Super !!! - Genau so ist - die Inject Node kannst wegschmeissen - die habe ich nur gebraucht - weil ich ja keinen MaxCube Adapter habe.

                                            wenn der kleiner oder gleich 85 ist dann dürfen erst die setpoints gesetzt werden.

                                            Nur wie kommt das OK des duty Cycle in den Hauptflow?

                                            In diesem Fall wird die flow Variable dutyCycleOK auf true oder false gesetzt und dann unten in dem Flow abgefragt. Das ist nötig, da die Ereignisse ja nicht gleichzeitig an der selben Node ankommen.
                                            Deswegen wird die flowVariable zeitlich unabhängig vom eigentlichen Flow gesetzt.

                                            Dachte eigentlich weil der duty cycle check unabhängig vom restflow ist und quasi obendrüber gesetzt wird, sendet er ein okay in den flow, was dann unten abgefragt wird.

                                            5fff9103-2f30-445b-ba18-ef9e48941c3d-image.png

                                            In der switch Node wird der Inhalt der flowVariablen abgefragt und dann der Flow entweder blockiert oder durchgelassen.

                                            Das hab ich aber doch auch so geschildert.
                                            Jetzt nicht mit fremden Federn schmücken, bitte 🙂

                                            Die wichtigen Dinge markiere ich Dir immer farbig:

                                            420e0f4c-34a4-46d7-a908-34f441e15c81-image.png

                                            Du kannst Dir den Inhalt Deiner Kontextdaten wie folgt anschauen:

                                            6d5ec0ee-1588-4f25-b7d6-d18b23559b23-image.png

                                            Im Kontextfenster siehst Du dann den Inhalt der Kontextvariablen - in diesem Fall der Flowvariable dutyCycleOK

                                            2fabce2c-d93b-41ba-b01d-fafea6a41776-image.png

                                            hier musst Du aber immer manuell aktualisieren

                                            8fea593e-43e5-4105-a768-3fecd0fa5e00-image.png

                                            Das habe ich mir angesehen. Bestätigt mich irgendwie in der Aussage, dass diese flow dutyCycle irgendwo aus dem aktuellen flow geholt wird.
                                            Die globale Heizungssteuerung ist ja auf global auch true

                                            Sorry - darauf gehe ich nun nicht ein. Ich habe es exakt erklärt.

                                            Die switch Node prüft den Wert des Duty Cycles und leitet das NAchrichtenobjekt je nach Wert des DutyCycles an den oberen oder untern Ausgang. Ist der DutyCycle über 85 wird die flow Variable mit der anschließenden Change Node auf false (unten) oder true (oben) gesetzt. Ist der dutyCycle über 85 bekommst Du nun eine Warnung im iobroker Log.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            401
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            867
                                            160248
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo