Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Verknüpfen mehrerer Objekte mit Blockly

    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

    Verknüpfen mehrerer Objekte mit Blockly

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

      würde sich für so etwas nicht ggf. auch der "Szenen" Adapter anbieten?

      Wenn alle Werte der Szene dem entsprechenden Wert besitzen dann ist die gesamte Szene true,

      bei nur einer Abweichung ist die Szene im Status "ungewiss" und nun würde ich mir den/de Übeltäter heraussuchen

      Ich kann auch recht einfach die Szene erweitern und sogar direkt einzelne Status erkennen

      fällt mir gerade so ein 🙂

      1 Reply Last reply Reply Quote 0
      • fu_zhou
        fu_zhou last edited by

        Wenn es nicht unbedingt Blockly sein muss, schau mal in meinem Thread. Das Skript funktioniert und ist leicht nachvollziehbar…

        1 Reply Last reply Reply Quote 0
        • H
          hmanfred last edited by

          Ich muss diesen Thread jetzt noch mal aufwärmen, denn ich komme endlich dazu, meine Anforderung umzusetzen.

          Zur Erinnerung:

          Es geht um einen Summenindikator, der anzeigt, ob eines von vielen Objekten auf "false" steht. Der Summenindikator zeigt mir auf meinem Main-View in VIS an, ob irgendeine Störung vorliegt, die ich dann auf einer Detailseite ansehen kann.

          Weiter oben wurde mir erklärt, dass ich zum Triggern mehrere bis viele Objekte mit gleichem Zustand ver-odern kann, nämlich prinzipiell so:
          1599_clipboard01.jpg
          Dann verließen sie mich aber… :oops:

          Klar, ich könnte einfach den Befehl "Fehler_kritisch -> true" einsetzen. Aber wenn keines der Objekte mehr false ist, soll das Objekt Fehler_kritisch ja wieder auf false gehen. Also muss ich doch if/do/else einsetzen? Nur wie?

          Hilft mir da evtl. die Listenfunktion? Oder bin ich ganz auf dem Holzweg?

          Gruß

          Manfred

          1 Reply Last reply Reply Quote 0
          • rantanplan
            rantanplan last edited by

            @hmanfred:

            Klar, ich könnte einfach den Befehl "Fehler_kritisch -> true" einsetzen. Aber wenn keines der Objekte mehr false ist, soll das Objekt Fehler_kritisch ja wieder auf false gehen. Also muss ich doch if/do/else einsetzen? Nur wie? `
            Warum liest Du Deinen eigenen Thread nicht nochmals durch. Wurde alles schon mal gesagt :roll:

            Dein Trigger muss auf "geändert" reagieren, sonst bekommt er ja nicht beide Zuständer mit.

            Grüße

            1 Reply Last reply Reply Quote 0
            • H
              hmanfred last edited by

              Danke für deine Antwort.

              Natürlich habe ich meinen Thread nochmal durchgelesen.

              Die erste Antwort von AlCalzone hat mir "unwahr" und nicht geändert gezeigt.

              Alternativ schrieb er: "Ansonsten musst du "wurde geändert" auswählen und dann im Trigger selbst deine Prüfbedingung zusammenbauen."

              Und das (erneute) Zusammenbauen der Prüfbedingung hoffte ich mit dem Umsetzen des Screenshots von AlCalzone zu sparen.

              Ich hatte mit meinem beschränkten Wissen gehofft, dass ich die zum Triggern verknüpften Datenpunkte ("einer von vielen "false") nicht noch mal auflisten muss.

              Kann man da vielleicht was mit Listen machen?

              Aber wenns nicht anders geht, mache ich halt meinen "Rattenschwanz".

              Gruß

              Manfred

              1 Reply Last reply Reply Quote 0
              • paul53
                paul53 last edited by

                @hmanfred:

                Kann man da vielleicht was mit Listen machen? `
                Ja. Wenn man eine Oder-Verknüpfung der <u>Werte</u> der Datenpunkte möchte, muss man die Werte speichern (z.B. in einer Liste), um sie logisch verknüpfen zu können. Prinzip:

                493_blockly_multitrigger_oder_vals.jpg

                1 Reply Last reply Reply Quote 0
                • rantanplan
                  rantanplan last edited by

                  @paul53:

                  Ja. Wenn man eine Oder-Verknüpfung der <u>Werte</u> der Datenpunkte möchte, muss man die Werte speichern (z.B. in einer Liste), um sie logisch verknüpfen zu können. Prinzip: `
                  Den "Rattenschwanz" hat er damit aber immer noch. Nur an anderer Stelle 😉

                  1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 last edited by

                    Falls alle Datenpunkte Logikwerte sind und die Störung den gleichen Wert hat (im Beispiel: false), kann auch eine Schleife verwendet werden.

                    493_blockly_ssm_schleife.jpg

                    1 Reply Last reply Reply Quote 0
                    • H
                      hmanfred last edited by

                      @paul53:

                      Falls alle Datenpunkte Logikwerte sind und die Störung den gleichen Wert hat (im Beispiel: false), kann auch eine Schleife verwendet werden. `

                      Das ist so. Allerdings ist das dann immer noch ein ziemliches Gefrickel.

                      So sehr die Logik der Homematic-CCU immer verteufelt wird, in einem solchen Fall ist sie genial: bei der Auswahl eines Objektes kann man es in einer Zeile gleichzeitig als Trigger und als Entscheidungswert benutzen.

                      Vielleicht ist das Aufteilen in zwei Programme hier eine einfachere Lösung. Das ver-ODERn mit dem Wert "false" mit anschließendem unmittelbaren Setzen des Fehler-Indikators ist ja bereits beschrieben. Fürs zweite Programm zum Zurücksetzen müsste ich dann nur eine Lösung finden, mit der ich einfach alle "true" ver-UNDen kann.

                      :idea: oder ich übertrage alle Objekte als Systemvariable in die CCU und verarbeite sie dann :idea: (nicht ganz ernst gemeint 😉 )

                      1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 last edited by

                        Damit die Sammelstörung schon bei Scriptstart verfügbar ist, sollte die Abfrage der Liste mit den Werten in einer Funktion erfolgen.

                        493_blockly_ssm_schleife_funktion.jpg

                        1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 last edited by

                          @hmanfred:

                          Fürs zweite Programm zum Zurücksetzen müsste ich dann nur eine Lösung finden, mit der ich einfach alle "true" ver-UNDen kann. `
                          Damit bleibt der Aufwand der gleiche wie mit Triggerung auf Änderung und ODER-Bildung per Schleife.

                          1 Reply Last reply Reply Quote 0
                          • rantanplan
                            rantanplan last edited by

                            @hmanfred:

                            Das ist so. Allerdings ist das dann immer noch ein ziemliches Gefrickel. `
                            Man kann auch alles totquasseln 😞

                            Einfach mal machen. In der Zeit wo Du hier wegen einer "einfachen" Lösung diskutierst, könnte Dein Programm schon laufen.

                            Ich habe jetzt mal 3 Minuten "gefrickelt".
                            147_beispiel.png

                            Grüße

                            1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 last edited by

                              @rantanplan:

                              Ich habe jetzt mal 3 Minuten "gefrickelt". `
                              6 Mal getState() bei jedem Trigger ist zwar die einfachste, aber keine Resourcen schonende Lösung.

                              Da Störung = false gilt, sollten alle oder durch und ausgetauscht und bei der Ausgabe auf Fehler_kritisch wahr und unwahr getauscht werden. Dann stimmt die Logik.

                              1 Reply Last reply Reply Quote 0
                              • rantanplan
                                rantanplan last edited by

                                @paul53:

                                6 Mal getState() bei jedem Trigger ist zwar die einfachste, aber keine Resourcen schonende Lösung. `
                                ????

                                Wenn man 6 Geräte überwachen will, muss man 6 Geräte triggern. Wo das passiert ist doch egal.

                                Oder habe ich da etwas verpasst?
                                @paul53:

                                Da Störung = false gilt, sollten alle oder durch und ausgetauscht und bei der Ausgabe auf Fehler_kritisch wahr und unwahr getauscht werden. Dann stimmt die Logik. `
                                Woher hast Du denn die Info?

                                1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 last edited by

                                  @rantanplan:

                                  Woher hast Du denn die Info? `
                                  Aus dem ersten Beitrag, und
                                  @hmanfred:

                                  Es geht um einen Summenindikator, der anzeigt, ob eines von vielen Objekten auf "false" steht. `
                                  @rantanplan:

                                  Wenn man 6 Geräte überwachen will, muss man 6 Geräte triggern. `
                                  Das ist klar. Nur die 6 fache Wertabfrage mit "Wert vom Objekt ID" (getState(id).val) ist nicht optimal, da getState(id) eine recht komplexe Funktion ist, die die CPU entsprechend belastet.

                                  1 Reply Last reply Reply Quote 0
                                  • rantanplan
                                    rantanplan last edited by

                                    @paul53:

                                    Das ist klar. Nur die 6 fache Wertabfrage mit "Wert vom Objekt ID" (getState(id).val) ist nicht optimal, da getState(id) eine recht komplexe Funktion ist, die die CPU entsprechend belastet. `
                                    Dein Ansatz die IDs in eine Liste zu packen ist sehr interessant!!!

                                    Habe ich gerade mal ausprobiert. (Auf die Idee bin ich vorher gar nicht gekommen.)

                                    Habe noch nicht alles ausprobiert. Im Trigger kann ich fast alle interessanten Infos zum Auslöser abfragen.

                                    "Objekt ID" liefert nichts. Werde ich mir auf jeden Fall näher anschauen.

                                    1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 last edited by

                                      @rantanplan:

                                      "Objekt ID" liefert nichts. `
                                      Habe gerade mal mit boolschen Test-Datenpunkten getestet: "Objekt ID" liefert die ID des auslösenden Datenpunktes, das Script funktioniert wie erwartet.

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

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      722
                                      Online

                                      31.7k
                                      Users

                                      79.8k
                                      Topics

                                      1.3m
                                      Posts

                                      6
                                      31
                                      5382
                                      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