Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Test Adapter shuttercontrol v2.0.x

    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

    Test Adapter shuttercontrol v2.0.x

    This topic has been deleted. Only users with topic management privileges can see it.
    • F
      FoxRo @Negalein last edited by

      @negalein said in Test Adapter shuttercontrol v1.2.x:

      @foxro sagte in Test Adapter shuttercontrol v1.2.x:

      Genau

      Hi

      Konntest du im Debog-Log was erkennen?

      Hi
      Sorry, hab grad recht viel um die Ohren, Privat wie auch Beruflich.
      Habe mir dies mal angesehen und es sieht ja verdächtig danach aus, dass Dir der Rollo einen Streich spielt.
      Wenn man das log Ansieht steht beim eintreten in SunProtect für Wohnzimmer folgendes:

      Hier überprüft er ob er beschatten muss...

      2021-06-12 12:25:35.574 - debug: shuttercontrol.0 (24894) Rollo Wohnzimmer: Check basis for sunprotect. Height:100 > HeightDownSun: 50 AND Height:100 == currentHeight:100 AND currentHeight:100 == heightUp:100
      2021-06-12 12:25:35.574 - debug: shuttercontrol.0 (24894) Sunprotect for Rollo Wohnzimmer is active
      2021-06-12 12:25:35.575 - debug: shuttercontrol.0 (24894) Temperature outside: 25.11 > 25 AND Light: undefined > 15

      Hier wird dem Rollo der Auftrag erteilt, nach 50% zu fahren...

      2021-06-12 12:25:35.575 - info: shuttercontrol.0 (24894) Set ID: Rollo Wohnzimmer value: 50%
      2021-06-12 12:25:35.576 - debug: shuttercontrol.0 (24894) Sunprotect Rollo Wohnzimmer old height: 100% new height: 50%

      Hier kommt vom Aktor die Rückmeldung, dass er bei 96% steht.

      2021-06-12 12:25:37.421 - debug: shuttercontrol.0 (24894) Shutter state changed: Rollo Wohnzimmer old value = 100 new value = 96

      Worauf Shuttercontrol damit reagiert, dass der Rollo offensichtlich manuell gestoppt wurde und setzt deshalb gleich den Manu_Mode...

      2021-06-12 12:25:37.422 - debug: shuttercontrol.0 (24894) Rollo Wohnzimmer drived manually to 96. Old value = 100. New value = 96
      2021-06-12 12:25:37.426 - debug: shuttercontrol.0 (24894) Rollo Wohnzimmer Updated trigger action to Manu_Mode to prevent moving after window close

      Das hast Du auch sauber im Statuslog mit geloggt:

      Manu_Mode true history.0 2021-06-12 12:40:37.434
      Manu_Mode true shuttercontrol.0 2021-06-12 12:25:37.427
      sunProtect true shuttercontrol.0 2021-06-12 12:25:35.644

      Kurz darauf meldet ein weiteres Positionsupdate vom Aktor, dass der Rollo nun bei 50% angekommen ist...

      2021-06-12 12:25:51.704 - debug: shuttercontrol.0 (24894) Shutter state changed: Rollo Wohnzimmer old value = 100 new value = 50
      2021-06-12 12:25:51.704 - debug: shuttercontrol.0 (24894) Rollo Wohnzimmer Old value = 100. New value = 50. automatic is active

      Warum hier gemeldet wird, dass die Automatik noch aktiv sei verstehe ich im Moment noch nicht, sie ist es nämlich nicht mehr, da während des Runterfahrens ein, aus Sicht von Shuttercontrol, manueller Zwischenstopp eingelegt wurde.

      Die Extra-Einstellung zum überprüfen des Rollo Status kann so nicht ziehen, da immer nach dem Fahrauftrag auf die letzte Rückmeldung gewartet wird und dann aktualisiert wird. Wenn die letzte Rückmeldung nicht ganz mit dem Soll-Wert übereinstimmt, wird an dieser Stelle dann korrigiert. Wenn aber während es Fahrens ein Wert aus dem "nichts" als Update daher kommt, dann geht Shuttercontrol davon aus, dass der Rollo nun da steht.

      Weisst Du, warum der Aktor hier einen solchen (sorry) "Fantasie Wert" während dem Fahren liefert?

      Sorry, aber mir fällt es schwer, dir an dieser Stelle noch viel weiter helfen zu können.
      Bei Fragen zum Shuttercontrol und sein (inneres) Verhalten kann ich Dir aber gerne weiterhelfen wenns nochmals nötig wird.
      Viel Erfolg!

      Negalein 2 Replies Last reply Reply Quote 0
      • Negalein
        Negalein Global Moderator @FoxRo last edited by

        @foxro sagte in Test Adapter shuttercontrol v1.2.x:

        Weisst Du, warum der Aktor hier einen solchen (sorry) "Fantasie Wert" während dem Fahren liefert?

        Danke für deine ausführliche Antwort.

        Ja, das mit den Werten ist mir in Vis schon aufgefallen, wenn ein Rollo gefahren wird (zB von 100 auf 70), wird immer ein zusätzlicher Wert solange angezeigt, bis er auf der gewünschten Position angekommen ist (zB Ist 100, Soll 70; in der Vis bleibt dann zB 97 solange stehen, bis er auf 70 angekommen ist; erst dann stehen die 70 dort).

        Ich werde mal @foxriver76 fragen. Er ist am Homematic-Adapter beteiligt.

        1 Reply Last reply Reply Quote 0
        • Negalein
          Negalein Global Moderator @FoxRo last edited by

          @foxro sagte in Test Adapter shuttercontrol v1.2.x:

          Sorry, aber mir fällt es schwer, dir an dieser Stelle noch viel weiter helfen zu können.

          Hallo

          Hab gleich Antwort von @foxriver76 erhalten.

          CCU meldet den Wert so und glaube der DP Working wird auf true gesetzt so lange er fährt. Ich denke über den Working Dp sollte man sagen können, dass es gerade ne aktive Fahrt ist und kein endzustand. Ich denke der Hauptgrund dass gesendet wird von CCU ist auch dieser dp aber der Rollo ist halt schon losgefahren und daher so ein krummer Wert

          Eventuell kann @simatec dies als Kontrolle in den Adapter einbauen.
          Sind ja sicher einige mit Homematic Komponenten.

          Bei den Extra-Einstellungen bin ich schon auf 120. Das half auch nicht.

          F 1 Reply Last reply Reply Quote 0
          • F
            FoxRo @Negalein last edited by

            @negalein said in Test Adapter shuttercontrol v1.2.x:

            Eventuell kann @simatec dies als Kontrolle in den Adapter einbauen.
            Sind ja sicher einige mit Homematic Komponenten.

            Möchte hier keinen Streit vom Zaun brechen - ist eher ein wenig "Religion", muss aber anfügen, so wie ich das iOBroker Konzept bis jetzt verstehe, und wie andere Adapter ihre Endgeräte Spezifika in iOBroker integrieren, dann müsste dies der HM Adapter übernehmen und nicht jeder Adapter, welcher möglicherweise HM Geräte steuert.
            Da hält sich zb. der KNX Adapter penibel daran, keine KNX spezifischen Verhaltensweisen in iOBroker rein zu bringen.
            Aus meiner Sicht müsste also der HM Adapter dafür sorgen, dass es auf dem Positions DP kein Update gibt, solange der Working DP true ist. Denn wie @foxriver76 selbst schreibt, sind die Werte am Positions DP während dem Fahren ungültig. Ich meinte hier schon Logs gesehen zu haben, wo es während dem Fahren fortlaufend zu Updates kam.

            Wie geschrieben, die Extra-Einstellung wird an dieser Stelle ausgehebelt, da der DP für die Höhe von Shuttercontrol sogenannt "abonniert" wird und deshalb Änderungen da drauf direkt und ohne Delay in die Logik mit einbezogen werden. Wenn man diese Änderungen durch die Extra-Settings ganz ausblenden würde, dann wäre Shuttercontrol auf dem DP während dieser Extra-Einstellungen Zeit bei jeder Fahrt komplett blind und würde da nichts mit bekommen, egal was passiert. Dh. die Extra-Einstellungen würden wohl plötzlich zu einem kritischen "Fine-Tune" Element. Gute Ideen wären also gefragt, wenn der HM Adapter dies nicht übernimmt 😉

            Projektleiter von Shuttercontrol ist und bleibt @simatec und deshalb überlasse ich es ihm, ob und wie er zu diesem Verhalten eine Lösung anbieten will.

            Negalein 1 Reply Last reply Reply Quote 1
            • Negalein
              Negalein Global Moderator @FoxRo last edited by

              @foxro sagte in Test Adapter shuttercontrol v1.2.x:

              muss aber anfügen, so wie ich das iOBroker Konzept bis jetzt verstehe, und wie andere Adapter ihre Endgeräte Spezifika in iOBroker integrieren, dann müsste dies der HM Adapter übernehmen und nicht jeder Adapter, welcher möglicherweise HM Geräte steuert.

              Aus meiner Sicht müsste also der HM Adapter dafür sorgen, dass es auf dem Positions DP kein Update gibt, solange der Working DP true ist.

              Da bin ich voll deiner Meinung.
              Wenn es beim KNX-Adapter geht, kann es @foxriver76 vielleicht doch im HM-Adapter irgendwie bewerkstelligen.
              Es betrifft bestimmt noch andere Adapter oder in Zukunft welche, die mit dem Problem zu kämpfen haben.

              Ich bin kein Entwickler, kenne mich also 0 aus ob das möglich ist.
              Muss oder kann nur @foxriver76 entscheiden.

              K I 2 Replies Last reply Reply Quote 0
              • K
                Kuddel @Negalein last edited by

                Hallo zusammen,

                aktuell habe ich meine Rollo-Steuerung per Blockly realisiert und wollte mir jetzt mal diesen Adaopter anschauen.

                Bevor ich anfange zu testen, habe ich direkt mal eine Frage:

                Kann man Fenstersensoren integrieren, damit die ROllos nur auf z.B. 25% fahren, wenn ein Fenster gekippt ist?

                B da_Woody 2 Replies Last reply Reply Quote 0
                • B
                  bishop @Kuddel last edited by

                  @kuddel
                  ja, ist möglich!

                  K 1 Reply Last reply Reply Quote 0
                  • da_Woody
                    da_Woody @Kuddel last edited by

                    @kuddel die frage ist eher umgekehrt, können deine rollos alles das, was shuttercontrol kann! 😄

                    M 1 Reply Last reply Reply Quote 1
                    • M
                      Muchul @da_Woody last edited by

                      @da_woody
                      Welches Rollo kann das denn?
                      Grinsduckundwech

                      1 Reply Last reply Reply Quote 0
                      • T
                        tobitobsta last edited by

                        nochmal eine Frage zu den Shuttercontrol States:

                        soll es denn eigentlich so sein, dass jedes manuelle Hochfahren auf das Level 100%, den Status auf "none" ziehen soll und somit Sunprotect funktionieren sollte?

                        Bei mir ist das am Tag nur der Fall, wenn morgens das erste manuelle "hoch" gesetzt wird. Wenn im laufe des Tages einmal manuell runter und dann wieder manuell hoch (auf 100%) dann bleibt der State "ManuMode" (und SunProtect geht nicht mehr)
                        Soll das so? Oder mache ich was falsch? Ist das ein Bug?

                        da_Woody 1 Reply Last reply Reply Quote 0
                        • K
                          Kuddel @bishop last edited by

                          @bishop okay, habe die Einstellung gefunden.

                          Problem ist nur, dass ich teilweise pro Rollo zwei Fenster und zwei Densoren habe.

                          Kann man auch zwei Sensoren pro Rollo-Aktor hinterlegen?

                          da_Woody 1 Reply Last reply Reply Quote 0
                          • da_Woody
                            da_Woody @tobitobsta last edited by

                            @tobitobsta sagte in Test Adapter shuttercontrol v1.2.x:

                            "ManuMode"

                            an dem problem wird im moment rumgerätselt, wie man in diversen postings lesen kann...

                            1 Reply Last reply Reply Quote 0
                            • da_Woody
                              da_Woody @Kuddel last edited by

                              @kuddel sagte in Test Adapter shuttercontrol v1.2.x:

                              Kann man auch zwei Sensoren pro Rollo-Aktor hinterlegen?

                              grundsätzlich mal nicht. wird ohne trixxen nicht lösbar sein. (blockly für beide sensoren, die einen DP füllen.)

                              1 Reply Last reply Reply Quote 0
                              • I
                                IT-Veteran @Negalein last edited by

                                @negalein Hallo zusammen,

                                ich werde das Gefühl nicht los, dass die Ursache (mal wieder) an der Implementierung der Homematic Aktoren liegt. Ich hatte das hier schon mal thematisiert.

                                Die HmIP-Aktoren BROLL und FROLL benutzen den Kanal 3, um den IST-Zustand darzustellen. Die Kanäle 4, 5 und 6 werden benutzt, um SOLL zu setzen. Da Shuttercontrol nur einen Kanal verwenden kann, muss dies logischerweise 4, 5 oder 6 sein (ich verwende im Folgenden mal Kanal 4). Und genau da fängt das Problem an, denn Kanal 4 und Kanal 3 werden in der CCU nicht synchronisiert. Der richtige Wert nach dem Stopp des Rolladens steht deshalb ausschließlich in Kanal 3. In Kanal 4 steht der Sollwert, auch, wenn die Fahrt aus beliebigem Grund vorher gestoppt wurde. Hinzu kommt, dass nach dem Losfahren die Werte in Kanal 3 zufällig wechseln können. Nachdem der Rolladen angehalten hat, dauert es einige Zeit, bis in Kanal 3 der IST-Wert eingetragen wird.

                                Ich habe mal versucht, das durch ein kleines Skript in den Griff zu bekommen, das einfach den Status des Rolladens überprüft und, sobald dieser angehalten hat, mit einer Verzögerung von einigen Sekunden den Wert aus Kanal 3 in den Kanal 4 schreibt. Das hat jedoch aus nicht nachvollziehbaren Gründen nur teilweise funktioniert, weshalb ich es wieder aufgegeben habe.

                                Wollte man das Thema zuverlässig lösen, so müssten m.E. in Shuttercontrol zwei Kanäle (IST=3, SOLL=4 oder 5 oder 6) verwendet werden. Wie aufwändig diese Änderung wäre, kann ich natürlich nicht einmal ahnen.

                                M Negalein 2 Replies Last reply Reply Quote 0
                                • M
                                  Muchul @IT-Veteran last edited by

                                  @it-veteran
                                  Müsste sich das nicht durch Alias'e umgehen lassen?

                                  simatec 1 Reply Last reply Reply Quote 0
                                  • simatec
                                    simatec Developer Most Active @Muchul last edited by

                                    @muchul
                                    Genau durch Alias wurde das Thema hier schon einige male beschrieben. Für den Aktor einen Alias anlegen, indem IST und SOLL Werte des Aktors verknüpft werden und es läuft in shuttercontrol.
                                    Im Prinzip wurde Alias genau für solche Anwendungen geschaffen

                                    B H 2 Replies Last reply Reply Quote 0
                                    • Negalein
                                      Negalein Global Moderator @IT-Veteran last edited by

                                      @it-veteran sagte in Test Adapter shuttercontrol v1.2.x:

                                      Ich habe mal versucht, das durch ein kleines Skript in den Griff zu bekommen, das einfach den Status des Rolladens überprüft und, sobald dieser angehalten hat, mit einer Verzögerung von einigen Sekunden den Wert aus Kanal 3 in den Kanal 4 schreibt. Das hat jedoch aus nicht nachvollziehbaren Gründen nur teilweise funktioniert, weshalb ich es wieder aufgegeben habe.

                                      Ja, ging mir auch so.
                                      Bis ich den obigen Thread aufgemacht habe.
                                      Mit dem Alias sind die Werte passend.

                                      Leider hat es nichts mit dem aktuellen HM Problem zu tun.

                                      1 Reply Last reply Reply Quote 0
                                      • B
                                        bishop @simatec last edited by bishop

                                        @simatec sagte in Test Adapter shuttercontrol v1.2.x:

                                        @muchul
                                        Genau durch Alias wurde das Thema hier schon einige male beschrieben. Für den Aktor einen Alias anlegen, indem IST und SOLL Werte des Aktors verknüpft werden und es läuft in shuttercontrol.
                                        Im Prinzip wurde Alias genau für solche Anwendungen geschaffen

                                        gibt es hier für ein Beispiel?
                                        Wären dann 2 Datenpunkte in einem oder?

                                        Negalein 1 Reply Last reply Reply Quote 0
                                        • Negalein
                                          Negalein Global Moderator @bishop last edited by

                                          @bishop sagte in Test Adapter shuttercontrol v1.2.x:

                                          gibt es hier für ein Beispiel?

                                          // Original-Datenpunkt
                                          const idOrigin = 'hm-rpc.0.00115A49A5B2BE.4.LEVEL'/*Rollo Wohnzimmer :4 LEVEL*/ 
                                          // Optional: Status-Datenpunkt, wenn Kommando und Status getrennt.
                                          // Bei Nicht-Verwendung Leerstring '' zuweisen
                                          const idRead = 'hm-rpc.0.00115A49A5B2BE.3.LEVEL'/*Rollo Wohnzimmer :4 LEVEL*/
                                           
                                          // Alias-Datenpunkt
                                          const idAlias = 'Rollos.Rollo_Wohnzimmer';
                                           
                                          var typeAlias, read, write, nameAlias, role, desc, min, max, unit, states, custom, raum, gewerk;
                                           
                                          // Folgende kommentieren, wenn keine Änderung der Eigenschaft erforderlich
                                          nameAlias = 'Rollo Wohnzimmer';
                                          desc = 'per Script erstellt';
                                          // typeAlias = 'boolean'; // oder 'number'
                                          // read = "val < 0 ? -val : 0"; // Erkennung "Aus" --> false erfolgt automatisch  
                                          // write = "val ? String(1) : String(0)";
                                          // role = 'value';
                                          // min = 0; // nur Zahlen
                                          // max = 100; // nur Zahlen
                                          // unit = '%'; // nur für Zahlen
                                          // states = {0: 'Aus', 1: 'Auto', 2: 'Ein'}; // Zahlen (Multistate) oder Logikwert (z.B. Aus/Ein)
                                          custom = {}; // verhindert doppelte Ausführung von history, ...
                                          // raum = 'EG_Flur'; // Groß-/Kleinschreibung in der ID beachten !
                                          // gewerk = 'Licht'; // Groß-/Kleinschreibung in der ID beachten !
                                           
                                          // Ab hier nichts ändern !!
                                          function createAlias(idDst, idSrc, idRd) {
                                             if(existsState(idDst)) log(idDst + ' schon vorhanden !', 'warn');
                                             else {
                                                var obj = {};
                                                obj.type = 'state';
                                                obj.common = getObject(idSrc).common;
                                                obj.common.alias = {};
                                                if(idRd) {
                                                    obj.common.alias.id = {};
                                                    obj.common.alias.id.read = idRd;
                                                    obj.common.alias.id.write = idSrc;
                                                    obj.common.read = true;
                                                } else obj.common.alias.id = idSrc;
                                                if(typeAlias) obj.common.type = typeAlias;
                                                if(obj.common.read !== false && read) obj.common.alias.read = read;
                                                if(obj.common.write !== false && write) obj.common.alias.write = write;
                                                if(nameAlias) obj.common.name = nameAlias;
                                                if(role) obj.common.role = role;
                                                if(desc) obj.common.desc = desc;
                                                if(obj.common.type == 'number') {
                                                   if(min !== undefined) obj.common.min = min;
                                                   if(max !== undefined) obj.common.max = max;
                                                   if(unit) obj.common.unit = unit;
                                                } else {
                                                   if(obj.common.min !== undefined) delete obj.common.min;
                                                   if(obj.common.max !== undefined) delete obj.common.max;
                                                   if(obj.common.unit) delete obj.common.unit;
                                                }
                                                if(states) obj.common.states = states;
                                                if(custom && obj.common.custom) obj.common.custom = custom;
                                                obj.native = {};
                                                setObject(idDst, obj, function() {
                                                   if(idRd) setState(idRd, getState(idRd).val, true);
                                                   else setState(idSrc, getState(idSrc).val, true); 
                                                });
                                                if(raum && existsObject('enum.rooms.' + raum)) {
                                                   let obj = getObject('enum.rooms.' + raum)
                                                   obj.common.members.push(idDst);
                                                   setObject('enum.rooms.' + raum, obj);
                                                }
                                                if(gewerk && existsObject('enum.functions.' + gewerk)) {
                                                   let obj = getObject('enum.functions.' + gewerk)
                                                   obj.common.members.push(idDst);
                                                   setObject('enum.functions.' + gewerk, obj);
                                                }
                                             } 
                                          }
                                           
                                          createAlias('alias.0.' + idAlias, idOrigin, idRead);
                                          
                                          
                                          B 1 Reply Last reply Reply Quote 0
                                          • B
                                            bishop @Negalein last edited by bishop

                                            @negalein

                                            besten Dank 🙂

                                            ist das auch mit dem alias-manager zu machen?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            584
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            rollladen rollladensteuerung shuttercontrol
                                            328
                                            7330
                                            9693262
                                            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