Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Dynamisches Licht - Farbverlauf Tag/Nacht

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Dynamisches Licht - Farbverlauf Tag/Nacht

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

      Hallo nocheinmal,
      da ich die letzten Stunden nun versucht habe herauszufinden ob alles klappt und ich wieder nicht weiter komme hätte ich noch Fragen, sorry.... 😕

      • Skripte Astro, Dynamisches_Licht, Lichtschaltung laufen ohne Fehlermeldung

      • Die Datenpunkte werden unter Javaskript->Astro und Dynamisches_Licht angezeigt.

      Bei einigen dieser Datenpunkte bin ich unsicher ob das so sein soll:
      Astro -> Tageszeit -> Current bzw. next : "nächsten Wechsel abwarten"
      Astro -> Zeiten -> Astrotag: "false", die anderen Zeiten werden wie berechnet angezeigt
      Dynamisches_Licht -> Offset1: "null K"

      Denn... DIe Lampen habe ich eingetragen im Skript Lichtschaltung und ändern (bislang) nicht die Lichttemperatur.

      /** Lampe 1 **/
      var L1on = "hue.0.Flur.on";
      var L1ct = "hue.0.Flur.ct";
      var L1mode = "hue.0.Flur.colormode";
      

      vg

      M 1 Reply Last reply Reply Quote 0
      • M
        Malaus @vsa last edited by

        @vsa hast du Polling im Hue Adapter aktiviert?

        Bei mir sieht das gerade so aus:
        Bildschirmfoto 2020-01-05 um 21.48.06.png

        Bei Offset1 kannst du die Farbe nochmal per Hand anpassen. Schreib da mal lieber eine 0 rein.

        1 Reply Last reply Reply Quote 1
        • V
          vsa last edited by vsa

          @Malaus
          danke, das ist schon mal eine Hilfe. Bei mir siehts anders aus. Ich habe den Hue Adapter, nur bei Polling ist ein Häkchen.)

          Unter Tageszeit steht bei mir nur current und next mit jeweils "nächsten Wechsel abwarten". Der Datenpunkt Sunset wird wohl bei mir nicht übergeben.

          Bei Offset1 habe ich nun händisch 0 eingetragen.

          Dann suche ich mal weiter wo es bei mir hakt. Schon mal ein STückechen weiter durch deine Hilfe 🙂

          vgUnbenannt.jpg

          M 1 Reply Last reply Reply Quote 0
          • M
            Malaus @vsa last edited by

            @vsa warte mal bis morgen. Das bei dem current und next ändert sich erst, wenn da auch was passiert. Es ist ja nacht, also warte bis morgen mal ab. Sobald es morgen ist, wird das da stehen und als next Vormittag oder so.

            Der Datenpunkt Sunset hat nichts damit zu tun. Der gehört zu einem anderen Skript.

            V 1 Reply Last reply Reply Quote 1
            • V
              vsa @Malaus last edited by vsa

              @Malaus danke, mach ich. Ich suchte schon nach Sunset 😉

              1 Reply Last reply Reply Quote 0
              • V
                vsa last edited by

                @Malaus Vielen Dank für die Hilfen... so langsam steie ich durch. Das Skript läuft jetzt durch und schaltet zwei Meiner Hue Lampen (1x Lightstrip+, 1xGruppe Hue white ambience). Weitere werde ich nach und nach einbinden.
                VG

                1 Reply Last reply Reply Quote 1
                • V
                  vsa last edited by

                  Hallo

                  danke nochmals für die Bereitstellung des Skripts. Im Großen und Ganzen läufts von der Lichtgebung wie ich es mir wünschte. Die (für mich) fehlenden Tageszeiten habe ich Nachgetragen und entsprechend die Kelvin-Temp eingetragen.

                  Zu meinem Problem: Die Lichter gehen auf Tastendruck (Philips Hue Schalter, Lightstrips+, Hue WhiteAmbiance) auch an und wechseln die Temperatur, aber schon nach wenigen Sekunden schalten sich die Lichter wieder aus. Auch beim wiederholten Anschalten (egal ob per Taster oder HueApp oder AppleHome) gehen sie nach wenigen Sekunden wieder aus.

                  Wenn ich das Lichtschaltungsskript vor dem Einschalten deaktiviere, und nach dem Einschalten wieder aktiviere, belein die Leuchten an. Also womöglich liegt der Fehler beim Lichtschaltungsskript?

                  Für Hilfe wäre ich dankbar 🙂
                  VG

                  /*** Leuchten ***/
                  
                  /** Lampe 1 **/
                  
                  var L1on = "hue.0.Hue_Lightstrip_Flur.on";
                  var L1ct = "hue.0.Hue_Lightstrip_Flur.ct";
                  var L1mode = "hue.0.Hue_Lightstrip_Flur.colormode";
                  
                  
                  /** Lampe 2 **/
                  
                  var L2on = "hue.0.Hue_ambiance_links.on";
                  var L2ct = "hue.0.Hue_ambiance_links.ct";
                  var L2mode = "hue.0.Hue_ambiance_links.colormode";
                  
                  
                  /** Lampe 3 **/
                  
                  var L3on = "hue.0.Hue_ambiance_rechts.on";
                  var L3ct = "hue.0.Hue_ambiance_rechts.ct";
                  var L3mode = "hue.0.Hue_ambiance_rechts.colormode";
                  
                  
                  /** Lampe 4 **/
                  
                   
                  //var L4on = "";
                  //var L4ct = "";
                  
                   
                  var Dynamiclight = "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin";
                  var Offset1 = 'javascript.0.Dynamisches_Licht.Offset1';
                  var Offset2 = 'javascript.0.Dynamisches_Licht.Offset2';
                  var Offset3 = 'javascript.0.Dynamisches_Licht.Offset3';
                  var Offset4 = '';
                  
                  var K1;
                  var K2;
                  var K3;
                  
                  
                  //**PROGRAM **//
                  
                  function getStateKelvin () {
                      K1 = getState(Dynamiclight).val + getState(Offset1).val;
                      K2 = getState(Dynamiclight).val + getState(Offset2).val;
                      K3 = getState(Dynamiclight).val + getState(Offset3).val;
                      lightcheck ();
                      return K1.val, K2.val, K3.val
                  }
                  
                  
                  function lightcheck () {
                      if (getState (L1on).val == true){
                          Kelvin1 ();
                      }
                  
                      if (getState (L2on).val == true){
                          Kelvin2 ();
                      }
                  
                      if (getState (L3on).val == true){
                          Kelvin3 ();
                      } 
                  
                      else return;
                  }
                  
                   
                  
                  function Kelvin1 () {
                      if (getState(L1mode).val == "ct"){  
                               setState(L1ct, K1);
                       } 
                  }
                  
                  function Kelvin2 () { 
                      if (getState(L2mode).val == "ct"){
                      setState(L2ct, K2);
                      } 
                  }
                  
                  
                  
                  function Kelvin3 () {
                      if (getState(L3mode).val == "ct"){  
                         setState(L3ct, K3);
                     } 
                  }
                  
                  
                  /** Offsets der Leuchten erstellen **/
                  
                  createState(Offset1, {
                     name: 'Offset1',
                     unit: 'K',
                     type: 'number',
                  });
                  
                  createState(Offset2, {
                     name: 'Offset2',
                     unit: 'K',
                     type: 'number',
                  });
                  
                  createState(Offset3, {
                     name: 'Offset3',
                     unit: 'K',
                     type: 'number',
                  });
                  
                  
                  /** Datenpunkte abfragen **/
                  
                  on({ id: L1on, val: true }, Kelvin1);
                  on({ id: L2on, val: true }, Kelvin2);
                  on({ id: L3on, val: true }, Kelvin3);
                  
                  /**
                  on({ id: L3on, change: "any" }, Kelvin3); 
                  */
                  
                  on({ id: Dynamiclight, change: "any" }, getStateKelvin);
                  
                  
                  M 1 Reply Last reply Reply Quote 0
                  • M
                    Malaus @vsa last edited by

                    @vsa
                    hatte das Problem auch. Vermute mal da gabs irgendein Update, wo sich was geändert hat.
                    Die Lösung ist, bevor man die Farbe der Lampe setzt, ein

                    setState(L1on, true);
                    

                    einzusetzen.

                    Bei deinem wäre das nun so:

                     
                    function Kelvin1 () {
                        if (getState(L1mode).val == "ct"){  
                                 setState(L1on, true);
                                 setState(L1ct, K1);
                         } 
                    }
                    
                    
                    1 Reply Last reply Reply Quote 1
                    • V
                      vsa last edited by

                      @Malaus said in Dynamisches Licht - Farbverlauf Tag/Nacht:

                      Du bist super! Danke für die sehr schnelle Hilfe - funktioniert jetzt! Muss wohl an irgendeinem Update gelegen haben, denn vorher gings ja auch...

                      Schönen Sonntag noch,
                      vg

                      1 Reply Last reply Reply Quote 0
                      • V
                        vsa last edited by

                        ... sorrry nocheinmal...

                        nur die logs laufen mit warn voll:

                        Unbenannt.JPG

                        vg

                        M 1 Reply Last reply Reply Quote 0
                        • M
                          Malaus @vsa last edited by Malaus

                          @vsa
                          habs dir verbessert, in dem ich K1,K2 usw als Datenpunkte erstellt hab.
                          Allerdings ist mir ein anderer Fehler noch aufgefallen. Und zwar wird das Level also die Helligkeit jedes mal mit 100 überschrieben.
                          Muss ich mir mal genauer anschauen und ausprobieren, wie man das lösen kann.

                          Hier hast mal eine Zwischenlösung, damit wenigstens die Warnungen weg sind.

                          /*** Leuchten ***/
                           
                          /** Lampe 1 **/
                           
                          var L1on = "hue.0.Hue_Lightstrip_Flur.on";
                          var L1ct = "hue.0.Hue_Lightstrip_Flur.ct";
                          var L1mode = "hue.0.Hue_Lightstrip_Flur.colormode";
                           
                           
                          /** Lampe 2 **/
                           
                          var L2on = "hue.0.Hue_ambiance_links.on";
                          var L2ct = "hue.0.Hue_ambiance_links.ct";
                          var L2mode = "hue.0.Hue_ambiance_links.colormode";
                           
                           
                          /** Lampe 3 **/
                           
                          var L3on = "hue.0.Hue_ambiance_rechts.on";
                          var L3ct = "hue.0.Hue_ambiance_rechts.ct";
                          var L3mode = "hue.0.Hue_ambiance_rechts.colormode";
                           
                           
                          /** Lampe 4 **/
                           
                           
                          //var L4on = "";
                          //var L4ct = "";
                           
                           
                          var Dynamiclight = "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin";
                          var Offset1 = 'javascript.0.Dynamisches_Licht.Offset1';
                          var Offset2 = 'javascript.0.Dynamisches_Licht.Offset2';
                          var Offset3 = 'javascript.0.Dynamisches_Licht.Offset3';
                          var Offset4 = '';
                           
                          var K1 = 'javascript.0.Dynamisches_Licht.K1';
                          var K2 = 'javascript.0.Dynamisches_Licht.K2';
                          var K3 = 'javascript.0.Dynamisches_Licht.K3';
                           
                           
                          //**PROGRAM **//
                           
                          function getStateKelvin () {
                              setState(K1, getState(Dynamiclight).val + getState(Offset1).val);
                              setState(K2, getState(Dynamiclight).val + getState(Offset2).val);
                              setState(K3, getState(Dynamiclight).val + getState(Offset3).val);
                              lightcheck ();
                              
                          }
                           
                           
                          function lightcheck () {
                              if (getState (L1on).val == true){
                                  Kelvin1 ();
                              }
                           
                              if (getState (L2on).val == true){
                                  Kelvin2 ();
                              }
                           
                              if (getState (L3on).val == true){
                                  Kelvin3 ();
                              } 
                           
                              else return;
                          }
                           
                           
                           
                          function Kelvin1 () {
                              if (getState(L1mode).val == "ct"){ 
                                  setState(L1on, true); 
                                       setState(L1ct, getState(K1).val);
                               } 
                          }
                           
                          function Kelvin2 () { 
                              if (getState(L2mode).val == "ct"){
                              setState(L2ct, getState(K2).val);
                              } 
                          }
                           
                           
                           
                          function Kelvin3 () {
                              if (getState(L3mode).val == "ct"){  
                                 setState(L3ct, getState(K3).val);
                             } 
                          }
                           
                           
                          /** Offsets der Leuchten erstellen **/
                           
                          createState(Offset1, {
                             name: 'Offset1',
                             unit: 'K',
                             type: 'number',
                          });
                           
                          createState(Offset2, {
                             name: 'Offset2',
                             unit: 'K',
                             type: 'number',
                          });
                           
                          createState(Offset3, {
                             name: 'Offset3',
                             unit: 'K',
                             type: 'number',
                          });
                           
                          createState(K1, {
                             name: 'K1',
                             unit: 'K',
                             type: 'number',
                          });
                          
                          createState(K2, {
                             name: 'K2',
                             unit: 'K',
                             type: 'number',
                          });
                          
                          createState(K3, {
                             name: 'K1',
                             unit: 'K',
                             type: 'number',
                          }); 
                          /** Datenpunkte abfragen **/
                           
                          on({ id: L1on, val: true }, Kelvin1);
                          on({ id: L2on, val: true }, Kelvin2);
                          on({ id: L3on, val: true }, Kelvin3);
                           
                          /**
                          on({ id: L3on, change: "any" }, Kelvin3); 
                          */
                           
                          on({ id: Dynamiclight, change: "any" }, getStateKelvin);
                          
                          1 Reply Last reply Reply Quote 1
                          • V
                            vsa last edited by

                            @Malaus said in Dynamisches Licht - Farbverlauf Tag/Nacht:

                            setState(L1on, true);

                            Wieder ein dankeschön für das korrigieren&verbessern des Skriptes.
                            Wenn in der Zeile 73 -> setState(L1on, true);
                            steht, bekomme ich einige warns und die logs laufen voll. Wenn ich es entferne, klappt es....

                            vg

                            M 1 Reply Last reply Reply Quote 0
                            • M
                              Malaus @vsa last edited by

                              @vsa wenn du das weg lässt, hast du aber wieder das Problem, dass es sofort ausgeht oder?

                              1 Reply Last reply Reply Quote 0
                              • V
                                vsa last edited by

                                Tja, eigentlich ja schon. Aber gerade geht es... seltsam....! Da die logs vollgelaufen sind und mein Raspi nicht mhr reagiert hat, habe ich ihn vom Strom genoimmen und neu gestartet...

                                M 1 Reply Last reply Reply Quote 0
                                • M
                                  Malaus @vsa last edited by

                                  @vsa das mit dem Neustart hat bei mir auch für Wunder gesorgt. Jetzt läuft wieder alles 🙂

                                  1 Reply Last reply Reply Quote 0
                                  • V
                                    vsa last edited by

                                    Hallo @Malaus,

                                    nochmals ein feedback. Ich habe gestern Abend noch eine Weile daran rumgespielt.... Der Aufruf setState(L1on, true); bringt die logs zum überquellen und der Raspi reagiert nicht mehr.

                                    Daher habe ich gestern mal (wie oben erwähnt) die Zeile setState(L1on, true); weggelassen und es ging mehrmals mit dem EIn-/Ausschalten der Lampen, so wie es eben sein soll.

                                    Heute Mittag, wieder das gleiche Phänomen.... Nach dem Einschalten der Lampen gehen sie sofort wieder aus. Eigentlich seltsam. Eigentlich prüft ja die Funktion lightcheck() ob der Status an oder aus (true/false) ist. Kann es sein, dass es ein Timing Prolem sein könnte?

                                    VG ,

                                    1 Reply Last reply Reply Quote 0
                                    • V
                                      vsa last edited by

                                      ...ich habs mal versucht... jetzt gehts (mal wieder. mal sehen wie lange.) Ich bleibe dran und werde berichten.

                                      
                                      function Kelvin1 () {
                                          if (getState(L1mode).val == "ct"){ 
                                                  setTimeout(() => { setState(L1ct, getState(K1).val); }, 3000);
                                                  
                                           } 
                                      }
                                      
                                      
                                      M 1 Reply Last reply Reply Quote 0
                                      • M
                                        Malaus @vsa last edited by

                                        @vsa wie sah das log aus?

                                        V 1 Reply Last reply Reply Quote 0
                                        • V
                                          vsa @Malaus last edited by

                                          @Malaus leider genau so wie oben schon gepostet. geht ins unendliche....
                                          Bisher zeigt das log keine AUfälligkeiten mit dem eingebauten delay... toitoitoi...
                                          vg

                                          V 1 Reply Last reply Reply Quote 0
                                          • V
                                            vsa @vsa last edited by

                                            @Malaus So.... jetzt nocheinmal mein feedback:

                                            • Deine Skripte laufen super, bis auf dass seit irgendeinem Update die eigeschaltenen Lichter gleich wieder ausgehen.!
                                            • Ein setState(L1on, true); hilft zwar, dass die Lichter anbleiben. Die Logs laufen jedoch voll und der ioBroker reagiert kaum noch.
                                            • Die obige Änderung von mir mit setTimeout ist - zumindest bei mir - absolut notwendig, und so funktioniert es ohne dass die logs vollaufen. Vielleicht liegt es am langsameren Raspi? Wie auch immer...

                                            Vg

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.0k
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript template
                                            13
                                            104
                                            12950
                                            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