Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Dynamisches Licht - Farbverlauf Tag/Nacht

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    10
    1
    152

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.4k

Dynamisches Licht - Farbverlauf Tag/Nacht

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascripttemplate
104 Beiträge 13 Kommentatoren 18.5k Aufrufe 27 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • D dmode

    @lalalalala

    Hallo und guten Morgen zusammen!

    Zunächst an lalalalala mal ein riesiges Dankeschön als Ersteller und an el_malto fürs mittesten und Entwickeln. Supercoole Sache.. genaus sowas habe ich auch gesucht!
    Als blutiger Anfänger muss ich aber ne doofe Frage stellen.
    Habe ich es richtig verstanden, dass das Projekt sich aus den 3 Scripten "Astrofunktion" " das Script, wo ich den Wert an die Lampen weitergebe" und das Hauptscript "Lichtverlauf" welches lalalalala zuletzt aktualisiert hat!?
    Kann ich die 3 Scripte einfach unter common reinkopieren oder muss ich ausser bei dem Lampenscript noch was anpassen?
    Beste Grüße
    Dirk

    E Offline
    E Offline
    el_malto
    schrieb am zuletzt editiert von
    #33

    @dmode
    Das Projekt an sich setzt sich aus zwei Skripten zusammen.

    1. Skript "Astrofunktion" aus dem ersten Beitrag:
      Dieses Skript erstellt Datenpunkte mit den Astro Uhrzeiten und Tageszeiten. Diese Datenpunkte werden dann für die Berechnung in dem zweiten Skript benutzt.

    2. Skript ist quasi das "rechen Skript" welches @lalalalala als letztes gepostet hat:
      In diesem Skript kannst du deine Kelvin Werte eintragen die du zu bestimmten Tageszeiten haben willst. Das Skript berechnet dann die differenz der Tageszeiten in Minuten und die differenz der Kelvin Werte. So weiß das Skript die Anzahl der Schritte und die Höhe der Kelvin Werte um die es den "Hilfswert Kelvin" addieren oder subtrahieren muss. Diesen Datenpunkt kannst du dann für weitere Skripte benutzen in dem du den Kelvin Wert an deine Leuchten übergibst.

    Du kannst die beiden Skripte einfach unter common reinkopieren und Starten. Die ganzen Datenpunkte findest du dann unter Javaskript->Astro und Javaskript->Dynamisches_Licht.

    M 1 Antwort Letzte Antwort
    0
    • E el_malto

      @dmode
      Das Projekt an sich setzt sich aus zwei Skripten zusammen.

      1. Skript "Astrofunktion" aus dem ersten Beitrag:
        Dieses Skript erstellt Datenpunkte mit den Astro Uhrzeiten und Tageszeiten. Diese Datenpunkte werden dann für die Berechnung in dem zweiten Skript benutzt.

      2. Skript ist quasi das "rechen Skript" welches @lalalalala als letztes gepostet hat:
        In diesem Skript kannst du deine Kelvin Werte eintragen die du zu bestimmten Tageszeiten haben willst. Das Skript berechnet dann die differenz der Tageszeiten in Minuten und die differenz der Kelvin Werte. So weiß das Skript die Anzahl der Schritte und die Höhe der Kelvin Werte um die es den "Hilfswert Kelvin" addieren oder subtrahieren muss. Diesen Datenpunkt kannst du dann für weitere Skripte benutzen in dem du den Kelvin Wert an deine Leuchten übergibst.

      Du kannst die beiden Skripte einfach unter common reinkopieren und Starten. Die ganzen Datenpunkte findest du dann unter Javaskript->Astro und Javaskript->Dynamisches_Licht.

      M Offline
      M Offline
      Malaus
      schrieb am zuletzt editiert von
      #34

      @el_malto gibt es bei dir was neues bezüglich des Skripts? Also funktioniert nun alles?

      @dmode an dem Skript, wo die Werte an die jeweilige Lampen weitergegeben werden, bin ich momentan dran. Dort wird dann einfach nur geprüft, ob die Lampe an ist oder nicht. Falls ja, wird der aktuelle Kelvin Wert übergeben (1x in der Minute).
      Das kann man später auch in das aktuelle Skript einbauen, so dass man nur noch eins hat.

      E D 2 Antworten Letzte Antwort
      1
      • M Malaus

        @el_malto gibt es bei dir was neues bezüglich des Skripts? Also funktioniert nun alles?

        @dmode an dem Skript, wo die Werte an die jeweilige Lampen weitergegeben werden, bin ich momentan dran. Dort wird dann einfach nur geprüft, ob die Lampe an ist oder nicht. Falls ja, wird der aktuelle Kelvin Wert übergeben (1x in der Minute).
        Das kann man später auch in das aktuelle Skript einbauen, so dass man nur noch eins hat.

        E Offline
        E Offline
        el_malto
        schrieb am zuletzt editiert von el_malto
        #35

        @lalalalala
        Jo, dass Skript läuft bei mir.
        Bin auch noch gerade an einen Umrechnungsskript bei, welches von Kelvin nach RGB umwandelt da meine Ikea ja nur RGB können.
        Hier mal das Skript. Im JS-Adapter dann noch unter zusätzliche Module "kelvin-to-rgb" und "rgb-to-hex" eintragen:

        var kelvinToRgb = require('kelvin-to-rgb');
        var rgbToHex = require('rgb-to-hex');
        
        on({id: "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin"/*Hilfswert_Kelvin*/, change: "ne"}, function (obj) {
          var value = obj.state.val;
          var oldValue = obj.oldState.val;
          var K = getState("javascript.0.Dynamisches_Licht.Hilfswert_Kelvin").val;
          //console.log(K);
        
          // get [ r, g, b ] color
          var rgb = kelvinToRgb(K);
          //console.log(rgb);
        
        
          // Leerzeichen zwischen den r,g,b Werten setzen
          var r = rgb.slice(0, rgb.indexOf(',') - 1);
          //console.log(('r: ' + String(r)));
          var g = rgb.slice((rgb.indexOf(',') - 1), (rgb.lastIndexOf(',') + 1) - 1);
          //console.log(('g: ' + String(g)));
          var b = rgb.slice(((rgb.lastIndexOf(',') + 1) - 1), rgb.length);
          //console.log(('b: ' + String(b)));
          rgb = ['(\'rgb(',r,', ',g,', ',b,')\');'].join('');
          //console.log(rgb);
        
        
          //RGB zu HEX
          var hex = rgbToHex(rgb)
          //console.log(hex)
        
        
          //Zuordnung Leuchten
          setState('zigbee.0.14b457fffe43566d.color', '#' + hex);
        
        });
        

        Das Skript ist noch sehr zusammen "geklatscht". Gerade in den Zeile 15-22 habe ich das nach "try and error" probiert bis es klappte (wie gesagt, kein Plan von JS). Ich glaube auch das das Skript immer noch doppelt ausgeführt wird. Wenn man das im JS Adapter beobachtet wiederholen sich unten im Logfenster die Einträge doppelt. So als wenn es zwei mal durchläuft.
        Was ich da noch machen will_

        • Extra Datenpunkte für die R, G, B Werte und einen Datenpunkt für RGB Hex. Dann kann man sich das so zusammen bauen wir man will.
        • Code aufräumen

        Bin ich aus zeitlichen Gründen noch nicht zu gekommen. Hat bei mir gerade keine Priorität. Aber es läuft bisher ohne Probleme.

        1 Antwort Letzte Antwort
        0
        • D Offline
          D Offline
          dmode
          schrieb am zuletzt editiert von
          #36

          Danke euch fürs Feedback. Super interessant. Bei mir läuf´s jetzt auch :+1:

          1 Antwort Letzte Antwort
          1
          • M Malaus

            @el_malto gibt es bei dir was neues bezüglich des Skripts? Also funktioniert nun alles?

            @dmode an dem Skript, wo die Werte an die jeweilige Lampen weitergegeben werden, bin ich momentan dran. Dort wird dann einfach nur geprüft, ob die Lampe an ist oder nicht. Falls ja, wird der aktuelle Kelvin Wert übergeben (1x in der Minute).
            Das kann man später auch in das aktuelle Skript einbauen, so dass man nur noch eins hat.

            D Offline
            D Offline
            Denis1988
            schrieb am zuletzt editiert von Denis1988
            #37

            @lalalalala hey vielen Dank für das Skript hab es bei mir auch mal implementiert! Läuft super. Muss jetzt noch auch schauen wie ich es am besten mit den Lampen löse. Nicht dass die Lampen umgestellt werden, wenn ich gerade eine Szene laufen habe und so. Scheint bisschen komplexer zu sein.Hast du dein Skript für die Lampen bereits erstellt?

            LG

            M 1 Antwort Letzte Antwort
            0
            • D Denis1988

              @lalalalala hey vielen Dank für das Skript hab es bei mir auch mal implementiert! Läuft super. Muss jetzt noch auch schauen wie ich es am besten mit den Lampen löse. Nicht dass die Lampen umgestellt werden, wenn ich gerade eine Szene laufen habe und so. Scheint bisschen komplexer zu sein.Hast du dein Skript für die Lampen bereits erstellt?

              LG

              M Offline
              M Offline
              Malaus
              schrieb am zuletzt editiert von
              #38

              @Denis1988 bei mir sieht das so aus:

              var Light1 = "hue.0.Regal.on";
              var Light1ct = "hue.0.Regal.ct";
              var Light1mode = "hue.0.Regal.colormode";
              var Light2 = "hue.0.Licht.on"
              var Light2ct = "hue.0.Licht.ct";
              var Dynamic_Light = "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin";
              
              
              function Kelvin1 () {
                  if (getState(Light1).val == true && getState(Light1mode).val == "ct"){
                      setState(Light1ct, getState(Dynamic_Light));
                  }
              }
              
              function Kelvin2 () {
                  if (getState(Light2).val == true){
                      setState(Light2ct, getState(Dynamic_Light));
                  }
              }
              
              
              
              on({ id: Light1, change: "any" }, Kelvin1);
              on({ id: Light2, change: "any" }, Kelvin2);
              on({ id: Dynamic_Light, change: "any" }, Kelvin1);
              on({ id: Dynamic_Light, change: "any" }, Kelvin2);
              

              Bei der Function Kelvin1 frage ich nach dem Colormode ab. Wenn ich eine bestimmte Farbe drin habe, dann will ich ja nicht, dass das überschrieben wird.
              Das könntest du ja verwenden, sobald du eine Szene benutzt.

              D 1 Antwort Letzte Antwort
              1
              • M Malaus

                @Denis1988 bei mir sieht das so aus:

                var Light1 = "hue.0.Regal.on";
                var Light1ct = "hue.0.Regal.ct";
                var Light1mode = "hue.0.Regal.colormode";
                var Light2 = "hue.0.Licht.on"
                var Light2ct = "hue.0.Licht.ct";
                var Dynamic_Light = "javascript.0.Dynamisches_Licht.Hilfswert_Kelvin";
                
                
                function Kelvin1 () {
                    if (getState(Light1).val == true && getState(Light1mode).val == "ct"){
                        setState(Light1ct, getState(Dynamic_Light));
                    }
                }
                
                function Kelvin2 () {
                    if (getState(Light2).val == true){
                        setState(Light2ct, getState(Dynamic_Light));
                    }
                }
                
                
                
                on({ id: Light1, change: "any" }, Kelvin1);
                on({ id: Light2, change: "any" }, Kelvin2);
                on({ id: Dynamic_Light, change: "any" }, Kelvin1);
                on({ id: Dynamic_Light, change: "any" }, Kelvin2);
                

                Bei der Function Kelvin1 frage ich nach dem Colormode ab. Wenn ich eine bestimmte Farbe drin habe, dann will ich ja nicht, dass das überschrieben wird.
                Das könntest du ja verwenden, sobald du eine Szene benutzt.

                D Offline
                D Offline
                Denis1988
                schrieb am zuletzt editiert von Denis1988
                #39

                @lalalalala super das mit dem colormode ist schon mal super. was ist aber wenn eine bestimmte szene (gedimmtes Licht) ohne colormode an ist, dann wird diese doch trotzdem überschrieben oder täusche ich mich?

                M 1 Antwort Letzte Antwort
                0
                • D Denis1988

                  @lalalalala super das mit dem colormode ist schon mal super. was ist aber wenn eine bestimmte szene (gedimmtes Licht) ohne colormode an ist, dann wird diese doch trotzdem überschrieben oder täusche ich mich?

                  M Offline
                  M Offline
                  Malaus
                  schrieb am zuletzt editiert von Malaus
                  #40

                  @Denis1988

                  Die Helligkeit wird dabei nicht verändert.
                  Wenn du öfters eine Szene mit einem bestimmten Kelvinwert an hast, dann kannst du ja eine Ausnahme ins Skript schreiben.
                  Beispiel:

                  function Kelvin1 () {
                      if (getState(L1mode).val == "ct" && getState(L1ct).val != "3000"){
                          setState(L1ct, K1);
                      }
                  }
                  

                  Die "3000" ist die Farbe von deinem Weiß.

                  Edit:
                  Ich hab mein Skript gestern nochmal überarbeitet. Jetzt ist auf ein Offset dabei.

                  /*** Leuchten ***/
                  
                  /** Lampe 1 **/
                  
                  var L1on = "hue.0.Regal.on";
                  var L1ct = "hue.0.Regal.ct";
                  var L1mode = "hue.0.Regal.colormode";
                  
                  /** Lampe 2 **/
                  
                  var L2on = "hue.0.Licht.on";
                  var L2ct = "hue.0.Licht.ct";
                  
                  /** Lampe 2 **/
                  
                  //var L3on = "hue.0.Bad.on";
                  //var L3ct = "hue.0.Bad.ct";
                  
                  /** 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;
                  
                  //**PROGRAM **//
                  
                  function getStateKelvin () {
                  
                      K1 = getState(Dynamiclight).val + getState(Offset1).val;
                      K2 = getState(Dynamiclight).val + getState(Offset2).val;
                      lightcheck ();
                      return K1.val, K2.val
                  }
                  
                  function lightcheck () {
                  
                      if (getState (L1on).val == true){
                          Kelvin1 ();
                      }
                      if (getState (L2on).val == true){
                          Kelvin2 ();
                      }
                      else return;
                  }
                  
                  function Kelvin1 () {
                      if (getState(L1mode).val == "ct"){
                          setState(L1ct, K1);
                      }
                  }
                  
                  function Kelvin2 () { setState(L2ct, K2); }
                  
                  
                  /** 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, change: "any" }, Kelvin2);
                  on({ id: Dynamiclight, change: "any" }, getStateKelvin);
                  
                  D 1 Antwort Letzte Antwort
                  0
                  • M Malaus

                    @Denis1988

                    Die Helligkeit wird dabei nicht verändert.
                    Wenn du öfters eine Szene mit einem bestimmten Kelvinwert an hast, dann kannst du ja eine Ausnahme ins Skript schreiben.
                    Beispiel:

                    function Kelvin1 () {
                        if (getState(L1mode).val == "ct" && getState(L1ct).val != "3000"){
                            setState(L1ct, K1);
                        }
                    }
                    

                    Die "3000" ist die Farbe von deinem Weiß.

                    Edit:
                    Ich hab mein Skript gestern nochmal überarbeitet. Jetzt ist auf ein Offset dabei.

                    /*** Leuchten ***/
                    
                    /** Lampe 1 **/
                    
                    var L1on = "hue.0.Regal.on";
                    var L1ct = "hue.0.Regal.ct";
                    var L1mode = "hue.0.Regal.colormode";
                    
                    /** Lampe 2 **/
                    
                    var L2on = "hue.0.Licht.on";
                    var L2ct = "hue.0.Licht.ct";
                    
                    /** Lampe 2 **/
                    
                    //var L3on = "hue.0.Bad.on";
                    //var L3ct = "hue.0.Bad.ct";
                    
                    /** 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;
                    
                    //**PROGRAM **//
                    
                    function getStateKelvin () {
                    
                        K1 = getState(Dynamiclight).val + getState(Offset1).val;
                        K2 = getState(Dynamiclight).val + getState(Offset2).val;
                        lightcheck ();
                        return K1.val, K2.val
                    }
                    
                    function lightcheck () {
                    
                        if (getState (L1on).val == true){
                            Kelvin1 ();
                        }
                        if (getState (L2on).val == true){
                            Kelvin2 ();
                        }
                        else return;
                    }
                    
                    function Kelvin1 () {
                        if (getState(L1mode).val == "ct"){
                            setState(L1ct, K1);
                        }
                    }
                    
                    function Kelvin2 () { setState(L2ct, K2); }
                    
                    
                    /** 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, change: "any" }, Kelvin2);
                    on({ id: Dynamiclight, change: "any" }, getStateKelvin);
                    
                    D Offline
                    D Offline
                    Denis1988
                    schrieb am zuletzt editiert von
                    #41

                    @lalalalala Stimmt hast recht. Nur wenn die Lampe aus ist wird sie bei mir durch verändern des Kelvinwertes auf 100% gestellt. Ich beherrsche javascript leider nicht so wirklich. Was meinst du mit Offset?

                    M 1 Antwort Letzte Antwort
                    0
                    • D Denis1988

                      @lalalalala Stimmt hast recht. Nur wenn die Lampe aus ist wird sie bei mir durch verändern des Kelvinwertes auf 100% gestellt. Ich beherrsche javascript leider nicht so wirklich. Was meinst du mit Offset?

                      M Offline
                      M Offline
                      Malaus
                      schrieb am zuletzt editiert von
                      #42

                      @Denis1988

                      Ja, das ist nur beim einschalten. Das kann man ganz einfach damit umgehen:

                      var L1level = "hue.0.Regal.level";
                      
                      function Kelvin1 () {
                          if (getState(L1mode).val == "ct"){
                              setState(L1ct, K1);
                              setState(L1level, 50);
                          }
                      }
                      

                      Ich hab dir hier einmal eine neue Variable erstellt, wo du dahinter einfach nur den Namen deiner Lampe austauschen musst.
                      Und mit der Function Kelvin, hab ich setState(L1level, 50); angehängt. 50 ist der Wert, den du am Anfang haben willst. Möchtest du 30%, dann trage da 30 ein.

                      Zum Offset mein ich, wenn du mehrere Lampen unterschiedlicher Hersteller in einem Raum hast, dann willst du ja das diese die gleiche Farbe haben. Da allerdings jeder Hersteller andere Produkte verwendet, sind bei den Leuchten 4000 Kelvin nicht gleich 4000 Kelvin.
                      Beispiel:
                      Lampe 1 hat 4000 Kelvin
                      Lampe 2 hat 4000 Kelvin
                      aber sie strahlen nicht die gleich Farbe aus. Nun gehe ich an den Offset 1 und stelle -100 ein
                      Lampe 1 hat 3900 Kelvin
                      Lampe 2 hat 4000 Kelvin
                      Nun kommen wir schon näher, dass sie die gleiche Farbe haben.

                      Hoffe das Beispiel ist verständlich.

                      D 1 Antwort Letzte Antwort
                      1
                      • M Malaus

                        @Denis1988

                        Ja, das ist nur beim einschalten. Das kann man ganz einfach damit umgehen:

                        var L1level = "hue.0.Regal.level";
                        
                        function Kelvin1 () {
                            if (getState(L1mode).val == "ct"){
                                setState(L1ct, K1);
                                setState(L1level, 50);
                            }
                        }
                        

                        Ich hab dir hier einmal eine neue Variable erstellt, wo du dahinter einfach nur den Namen deiner Lampe austauschen musst.
                        Und mit der Function Kelvin, hab ich setState(L1level, 50); angehängt. 50 ist der Wert, den du am Anfang haben willst. Möchtest du 30%, dann trage da 30 ein.

                        Zum Offset mein ich, wenn du mehrere Lampen unterschiedlicher Hersteller in einem Raum hast, dann willst du ja das diese die gleiche Farbe haben. Da allerdings jeder Hersteller andere Produkte verwendet, sind bei den Leuchten 4000 Kelvin nicht gleich 4000 Kelvin.
                        Beispiel:
                        Lampe 1 hat 4000 Kelvin
                        Lampe 2 hat 4000 Kelvin
                        aber sie strahlen nicht die gleich Farbe aus. Nun gehe ich an den Offset 1 und stelle -100 ein
                        Lampe 1 hat 3900 Kelvin
                        Lampe 2 hat 4000 Kelvin
                        Nun kommen wir schon näher, dass sie die gleiche Farbe haben.

                        Hoffe das Beispiel ist verständlich.

                        D Offline
                        D Offline
                        Denis1988
                        schrieb am zuletzt editiert von
                        #43

                        @lalalalala super das werde ich gleich mal ausprobieren und berichten! Vielen dank vorab für deine tolle Arbeit!!!!!

                        1 Antwort Letzte Antwort
                        0
                        • V Offline
                          V Offline
                          vsa
                          schrieb am zuletzt editiert von vsa
                          #44

                          Hallo zusammen,

                          zunächst ein gutes Neues an Euch alle. Und ein herzliches Dankeschön für die Bereitstellung dieser Skripte. Die Idee ist echt toll, da ich auch immer wieder mit meinen hue-Lichtleisten daran gedacht hatte. Seit einigen Wochen habe ich mir ioBroker aufgesetzt und verwende das in Verbindung mit Homekit. Ich bin begeistert.... :-)
                          Ich bin leider (noch) ziviel "Anfänger" um alles komplett zu überblicken, daher einige Fragen:

                          Das Astroskript habe ich als "Astro" unter common abgelegt. unverändert
                          Das Skript "Dynamisches_Licht" von Malaus vom 12.11.19 auch. unverändert
                          Das dritte Skript "Lichtschaltung" vom 15.12.19 von Malaus habe ich angepasst auch in Common.

                          Das Skript für RGB benötge ich für Hue-Lampen wohl nicht, oder?

                          Unter den Datenpunkten sehe ich (scheinbar) sinnvolle Daten...

                          Aber:
                          Folgenden Error erhalte ich derzeit ständig im Log vom Astro-Skript:

                          18:05:03.141	error	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:607:45)
                          18:06:00.018	warn	javascript.0 (15119) at getAstroday (script.js.common.Astro:647:3)
                          18:06:00.019	warn	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:671:3)
                          
                          

                          Muss ich noch etwas ergänzen? Für eure Hilfe einen herzlichen Dank im voraus...
                          vg

                          M 1 Antwort Letzte Antwort
                          0
                          • V vsa

                            Hallo zusammen,

                            zunächst ein gutes Neues an Euch alle. Und ein herzliches Dankeschön für die Bereitstellung dieser Skripte. Die Idee ist echt toll, da ich auch immer wieder mit meinen hue-Lichtleisten daran gedacht hatte. Seit einigen Wochen habe ich mir ioBroker aufgesetzt und verwende das in Verbindung mit Homekit. Ich bin begeistert.... :-)
                            Ich bin leider (noch) ziviel "Anfänger" um alles komplett zu überblicken, daher einige Fragen:

                            Das Astroskript habe ich als "Astro" unter common abgelegt. unverändert
                            Das Skript "Dynamisches_Licht" von Malaus vom 12.11.19 auch. unverändert
                            Das dritte Skript "Lichtschaltung" vom 15.12.19 von Malaus habe ich angepasst auch in Common.

                            Das Skript für RGB benötge ich für Hue-Lampen wohl nicht, oder?

                            Unter den Datenpunkten sehe ich (scheinbar) sinnvolle Daten...

                            Aber:
                            Folgenden Error erhalte ich derzeit ständig im Log vom Astro-Skript:

                            18:05:03.141	error	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:607:45)
                            18:06:00.018	warn	javascript.0 (15119) at getAstroday (script.js.common.Astro:647:3)
                            18:06:00.019	warn	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:671:3)
                            
                            

                            Muss ich noch etwas ergänzen? Für eure Hilfe einen herzlichen Dank im voraus...
                            vg

                            M Offline
                            M Offline
                            Malaus
                            schrieb am zuletzt editiert von
                            #45

                            @vsa ist es das Astroskript von oben?

                            1 Antwort Letzte Antwort
                            0
                            • V Offline
                              V Offline
                              vsa
                              schrieb am zuletzt editiert von
                              #46

                              Ja, vom ersten Post....

                              M 1 Antwort Letzte Antwort
                              0
                              • V vsa

                                Ja, vom ersten Post....

                                M Offline
                                M Offline
                                Malaus
                                schrieb am zuletzt editiert von
                                #47

                                @vsa kann ehrlich gesagt mit den Log Daten nichts anfangen.

                                Ich hab dir hier mal das Astro Skript neu herauskopiert. Bei mir gibts da keinerlei Fehlermeldungen (JavaScript Version 4.3.0).

                                const sec = false; // Sekunden darstellen oder nicht
                                const fC = false; // forceCreation ein/aus
                                const pfad = "Astro"; // Pfad zum Objekt - Objektbaum-Hauptverzeichnis
                                // *****************************************************************************
                                // TAGESZEITEN - T E I L 
                                // Tageszeiten nach eigenem Gusto (Shifts siehe schedules weiter unten)
                                const tageszeiten = ["Nacht",
                                                   "Morgendämmerung",
                                                   "Sonnenaufgang",
                                                   "Morgen",
                                                   "Vormittag",
                                                   "Mittag",
                                                   "Nachmittag",
                                                   "Abend",
                                                   "Sonnenuntergang",
                                                   "Abenddämmerung"
                                                  ];
                                const idTageszeit = "javascript." + instance  + "." + pfad + ".Tageszeit.current" /*Tageszeit*/,
                                    idTageszeitNext = "javascript." + instance  + "." + pfad + ".Tageszeit.next";
                                 
                                createState(idTageszeit, "nächsten Wechsel abwarten", fC, {
                                  name: "Tageszeit",
                                  desc: "Name der Tageszeit",
                                  type: "string"
                                });   
                                createState(idTageszeitNext, "nächsten Wechsel abwarten", fC, {
                                  name: "nächste Tageszeit",
                                  desc: "Name der nächsten Tageszeit",
                                  type: "string"
                                });
                                function neue_tageszeit(abschnitt) {
                                  var akt = tageszeiten[parseInt(abschnitt, 10)],
                                  // wenn aktuelles Element ist letztes, dann nächstes ist erstes :-D
                                  nxt = (abschnitt + 1 === tageszeiten.length) ? tageszeiten[0] : tageszeiten[parseInt(abschnitt + 1, 10)];
                                  setState(idTageszeit, akt);
                                  setState(idTageszeitNext, nxt);
                                  log("neue Tagezeit: " + akt);
                                  log("nächte kommende Tagezeit: " + nxt);
                                }
                                // Nacht
                                schedule({
                                  astro: "nauticalDusk", 
                                  shift: 45
                                }, function () { 
                                  neue_tageszeit(0);
                                });
                                // Morgengdämmerung
                                schedule({
                                  astro: "nauticalDawn",
                                  shift: -45
                                }, function () {
                                  neue_tageszeit(1);
                                });
                                // Sonnenaufgang
                                schedule({
                                  astro: "dawn"
                                }, function() {
                                  neue_tageszeit(2);
                                });
                                // Morgen
                                schedule({
                                  astro: "sunriseEnd"
                                }, function () {
                                  neue_tageszeit(3);
                                });
                                // Vormittag 
                                schedule({
                                  astro: "goldenHourEnd",
                                  shift: 0
                                }, function () {
                                  neue_tageszeit(4);
                                });
                                // Mittag
                                schedule({
                                  astro: "solarNoon",
                                  shift: 0
                                }, function () {
                                  neue_tageszeit(5);
                                });
                                // Nachmittag
                                schedule({
                                  astro: "solarNoon",
                                  shift: 30
                                }, function () 
                                {
                                  neue_tageszeit(6);
                                });
                                // Abend
                                schedule({
                                  astro: "goldenHour",
                                  shift: 0
                                }, function () {
                                  neue_tageszeit(7);
                                });
                                // Sonnenuntergang
                                schedule({
                                  astro: "sunsetStart",
                                }, function () {
                                  neue_tageszeit(8);
                                });
                                // Abenddämmerung (nach Sonnenuntergang)
                                schedule({
                                  astro: "nauticalDusk"
                                }, function () {
                                  neue_tageszeit(9);
                                });
                                // *****************************************************************************
                                // A S T O - T E I L 
                                /* Objekt Astrotag 
                                 Astrotag liegt zwischen Sonnauf- und untergang, 
                                 Astronacht liegt zwischen Sonnenunter- und aufgang */
                                const idAstrotag =  "javascript." + instance + "." + pfad + ".Astrotag";
                                // Objekt für Uhrzeiten der Astrozeiten
                                const astrotime = {
                                  "elements" : [
                                      // Astrotag beginnt
                                      {
                                          "fname" : "sunrise", // function name
                                          "de" : {
                                              "name" : "Sonnenaufgang",
                                              "nxt" : "nächster",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Sunrise",
                                              "desc" : "top edge of the sun appears on the horizon"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      {
                                          "fname" : "sunriseEnd", // function name
                                          "de" : {
                                              "name" : "Ende Sonnenaufgang",
                                              "nxt" : "nächstes",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "End of sunrise",
                                              "desc" : "bottom edge of the sun touches the horizon"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      {
                                          "fname" : "goldenHourEnd", // function name
                                          "de" : {
                                              "name" : "Ende der goldenen Stunde am Morgen",
                                              "nxt" : "nächstes",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "End of golden hour",
                                              "desc" : "morning golden hour (soft light, best time for photography) ends"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      {
                                          "fname" : "solarNoon", // function name
                                          "de" : {
                                              "name" : "Sonnenhöchststand",
                                              "nxt" : "nächster",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Solar noon",
                                              "desc" : "sun is in the highest position"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      {
                                          "fname" : "goldenHour", // function name
                                          "de" : {
                                              "name" : "Goldene Stunde (am Abend)",
                                              "nxt" : "nächste",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Golden hour",
                                              "desc" : "evening golden hour starts"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      {
                                          "fname" : "sunsetStart", // function name
                                          "de" : {
                                              "name" : "Beginn Sonnenuntergang",
                                              "nxt" : "nächster",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Sunset starts",
                                              "desc" : "bottom edge of the sun touches the horizon"
                                          },
                                          "astroday" : true //during astroday
                                      },
                                      // Astronacht beginnt
                                      {
                                          "fname" : "sunset", // function name
                                          "de" : {
                                              "name" : "Sonnenuntergang",
                                              "nxt" : "nächster",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Sunset",
                                              "desc" : "sun disappears below the horizon, evening civil twilight starts"
                                          },
                                          "astroday" : false //during astronight
                                      },
                                      {
                                          "fname" : "dusk",
                                          "de" : {
                                              "name" : "Abenddämmerung",
                                              "nxt" : "nächste",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Dusk",
                                              "desc" : "evening nautical twilight starts"
                                          },
                                          "astroday" : false //during astronight
                                      },
                                      {
                                          "fname" : "nauticalDusk",
                                          "de" : {
                                              "name" : "nautische Abenddämmerung",
                                              "nxt" : "nächste",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Nautical dusk",
                                              "desc" : "evening astronomical twilight starts"
                                          },
                                          "astroday" : false //during astronight
                                      },
                                      {
                                          "fname" : "nadir",
                                          "de" : {
                                              "name" : "Nadir",
                                              "nxt" : "nächster",
                                              "desc" : "Fußpunkt gegenüber dem Zenit"
                                          },
                                          "en" : {
                                              "name" : "Nadir",
                                              "desc" : "darkest moment of the night, sun is in the lowest position"
                                          },
                                          "astroday" : false //during astronight
                                      },
                                      {
                                          "fname" : "nauticalDawn",
                                          "de" : {
                                              "name" : "nautische Morgendämmerung",
                                              "nxt" : "nächste",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "Nautical dawn",
                                              "desc" : "morning nautical twilight starts"
                                          },
                                          "astroday" : false //during astronight
                                      },
                                      {
                                          "fname" : "dawn",
                                          "de" : {
                                              "name" : "Morgendämmerung",
                                              "nxt" : "nächste",
                                              "desc" : ""
                                          },
                                          "en" : {
                                              "name" : "dawn",
                                              "desc" : "morning nautical twilight ends, morning civil twilight starts"
                                          },
                                          "astroday" : false //during astronight
                                      }
                                 
                                  ]
                                };
                                 
                                function writeAstroTimes(i) {
                                  // führende Nummer zur Sortierung in Admin/Objekte
                                  var nr = (i+1 < 10) ? "0" + (i+1) : (i+1);
                                  // Erstelle Objekt, falls nicht bereits vorhanden
                                  var idAstroObject = "javascript." + instance + "." + pfad + ".Zeiten." + nr + " - " + astrotime.elements[i].fname;
                                  createState(idAstroObject, " ", fC, {
                                      name: astrotime.elements[i].de.nxt + " " + astrotime.elements[i].de.name + " Uhrzeit",
                                      desc: astrotime.elements[i].en.desc,
                                      type: "string"
                                  });
                                 
                                  setTimeout(function() { // kurz warten, damit Objekte ggf. erst angelgt werden können
                                      var astrotag = getState(idAstrotag).val,
                                          temp;
                                      var today = new Date();
                                      var tomorrow = new Date(today.setDate(today.getDate()+1));
                                      var next_event;
                                      if (astrotag) { 
                                          // Wenn Tag (Aufgang vorbei (erst wieder morgen, Untergang kommt noch heute)
                                          next_event = (astrotime.elements[i].astroday) ? tomorrow : today; // prüfen
                                      } else { 
                                          // nach Nacht (Untergang vorbei (erst wieder morgen, Aufgang kommt heute oder morgen)
                                          next_event = (astrotime.elements[i].astroday) ? today : tomorrow; // prüfen
                                      }
                                      var fname = astrotime.elements[i].fname;
                                      temp = getAstroDate(fname, next_event);
                                      setState(idAstroObject, checkSec(temp.toLocaleTimeString('de-DE', { hour12: false })) );
                                  }, 3 * 1000);
                                }
                                 
                                // Zeit mit oder ohne Sekunden anzeigen
                                function checkSec (zeit) {
                                  if (!sec) {
                                      var newString_arr = zeit.split(":");
                                      var newString = newString_arr[0] + ":" + newString_arr[1];
                                      return (newString);
                                  } else return (zeit);
                                }
                                 
                                function getAstroday() {
                                  // Astrotag bestimmen (boolean)
                                  createState(idAstrotag, false, fC, {
                                      type: "boolean",
                                      name: "Astrologischer Tag",
                                      desc: "Liegt die aktuelle Zeit zwischen Sonnenauf- und untergang"
                                  }); 
                                  setState(idAstrotag, isAstroDay());
                                }
                                 
                                function iterateAstrotimes() {
                                  // Zeiten für jede Astrozeit schreiben
                                  for (var i = 0; i < astrotime.elements.length; i++) {
                                      writeAstroTimes(i);
                                  }
                                }
                                 
                                // Astrotag checken
                                schedule("*/1 * * * *", function () { // jede Minute
                                  getAstroday();
                                  iterateAstrotimes();
                                });
                                 
                                iterateAstrotimes();
                                getAstroday();
                                
                                V 1 Antwort Letzte Antwort
                                0
                                • M Malaus

                                  @vsa kann ehrlich gesagt mit den Log Daten nichts anfangen.

                                  Ich hab dir hier mal das Astro Skript neu herauskopiert. Bei mir gibts da keinerlei Fehlermeldungen (JavaScript Version 4.3.0).

                                  const sec = false; // Sekunden darstellen oder nicht
                                  const fC = false; // forceCreation ein/aus
                                  const pfad = "Astro"; // Pfad zum Objekt - Objektbaum-Hauptverzeichnis
                                  // *****************************************************************************
                                  // TAGESZEITEN - T E I L 
                                  // Tageszeiten nach eigenem Gusto (Shifts siehe schedules weiter unten)
                                  const tageszeiten = ["Nacht",
                                                     "Morgendämmerung",
                                                     "Sonnenaufgang",
                                                     "Morgen",
                                                     "Vormittag",
                                                     "Mittag",
                                                     "Nachmittag",
                                                     "Abend",
                                                     "Sonnenuntergang",
                                                     "Abenddämmerung"
                                                    ];
                                  const idTageszeit = "javascript." + instance  + "." + pfad + ".Tageszeit.current" /*Tageszeit*/,
                                      idTageszeitNext = "javascript." + instance  + "." + pfad + ".Tageszeit.next";
                                   
                                  createState(idTageszeit, "nächsten Wechsel abwarten", fC, {
                                    name: "Tageszeit",
                                    desc: "Name der Tageszeit",
                                    type: "string"
                                  });   
                                  createState(idTageszeitNext, "nächsten Wechsel abwarten", fC, {
                                    name: "nächste Tageszeit",
                                    desc: "Name der nächsten Tageszeit",
                                    type: "string"
                                  });
                                  function neue_tageszeit(abschnitt) {
                                    var akt = tageszeiten[parseInt(abschnitt, 10)],
                                    // wenn aktuelles Element ist letztes, dann nächstes ist erstes :-D
                                    nxt = (abschnitt + 1 === tageszeiten.length) ? tageszeiten[0] : tageszeiten[parseInt(abschnitt + 1, 10)];
                                    setState(idTageszeit, akt);
                                    setState(idTageszeitNext, nxt);
                                    log("neue Tagezeit: " + akt);
                                    log("nächte kommende Tagezeit: " + nxt);
                                  }
                                  // Nacht
                                  schedule({
                                    astro: "nauticalDusk", 
                                    shift: 45
                                  }, function () { 
                                    neue_tageszeit(0);
                                  });
                                  // Morgengdämmerung
                                  schedule({
                                    astro: "nauticalDawn",
                                    shift: -45
                                  }, function () {
                                    neue_tageszeit(1);
                                  });
                                  // Sonnenaufgang
                                  schedule({
                                    astro: "dawn"
                                  }, function() {
                                    neue_tageszeit(2);
                                  });
                                  // Morgen
                                  schedule({
                                    astro: "sunriseEnd"
                                  }, function () {
                                    neue_tageszeit(3);
                                  });
                                  // Vormittag 
                                  schedule({
                                    astro: "goldenHourEnd",
                                    shift: 0
                                  }, function () {
                                    neue_tageszeit(4);
                                  });
                                  // Mittag
                                  schedule({
                                    astro: "solarNoon",
                                    shift: 0
                                  }, function () {
                                    neue_tageszeit(5);
                                  });
                                  // Nachmittag
                                  schedule({
                                    astro: "solarNoon",
                                    shift: 30
                                  }, function () 
                                  {
                                    neue_tageszeit(6);
                                  });
                                  // Abend
                                  schedule({
                                    astro: "goldenHour",
                                    shift: 0
                                  }, function () {
                                    neue_tageszeit(7);
                                  });
                                  // Sonnenuntergang
                                  schedule({
                                    astro: "sunsetStart",
                                  }, function () {
                                    neue_tageszeit(8);
                                  });
                                  // Abenddämmerung (nach Sonnenuntergang)
                                  schedule({
                                    astro: "nauticalDusk"
                                  }, function () {
                                    neue_tageszeit(9);
                                  });
                                  // *****************************************************************************
                                  // A S T O - T E I L 
                                  /* Objekt Astrotag 
                                   Astrotag liegt zwischen Sonnauf- und untergang, 
                                   Astronacht liegt zwischen Sonnenunter- und aufgang */
                                  const idAstrotag =  "javascript." + instance + "." + pfad + ".Astrotag";
                                  // Objekt für Uhrzeiten der Astrozeiten
                                  const astrotime = {
                                    "elements" : [
                                        // Astrotag beginnt
                                        {
                                            "fname" : "sunrise", // function name
                                            "de" : {
                                                "name" : "Sonnenaufgang",
                                                "nxt" : "nächster",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Sunrise",
                                                "desc" : "top edge of the sun appears on the horizon"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        {
                                            "fname" : "sunriseEnd", // function name
                                            "de" : {
                                                "name" : "Ende Sonnenaufgang",
                                                "nxt" : "nächstes",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "End of sunrise",
                                                "desc" : "bottom edge of the sun touches the horizon"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        {
                                            "fname" : "goldenHourEnd", // function name
                                            "de" : {
                                                "name" : "Ende der goldenen Stunde am Morgen",
                                                "nxt" : "nächstes",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "End of golden hour",
                                                "desc" : "morning golden hour (soft light, best time for photography) ends"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        {
                                            "fname" : "solarNoon", // function name
                                            "de" : {
                                                "name" : "Sonnenhöchststand",
                                                "nxt" : "nächster",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Solar noon",
                                                "desc" : "sun is in the highest position"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        {
                                            "fname" : "goldenHour", // function name
                                            "de" : {
                                                "name" : "Goldene Stunde (am Abend)",
                                                "nxt" : "nächste",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Golden hour",
                                                "desc" : "evening golden hour starts"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        {
                                            "fname" : "sunsetStart", // function name
                                            "de" : {
                                                "name" : "Beginn Sonnenuntergang",
                                                "nxt" : "nächster",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Sunset starts",
                                                "desc" : "bottom edge of the sun touches the horizon"
                                            },
                                            "astroday" : true //during astroday
                                        },
                                        // Astronacht beginnt
                                        {
                                            "fname" : "sunset", // function name
                                            "de" : {
                                                "name" : "Sonnenuntergang",
                                                "nxt" : "nächster",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Sunset",
                                                "desc" : "sun disappears below the horizon, evening civil twilight starts"
                                            },
                                            "astroday" : false //during astronight
                                        },
                                        {
                                            "fname" : "dusk",
                                            "de" : {
                                                "name" : "Abenddämmerung",
                                                "nxt" : "nächste",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Dusk",
                                                "desc" : "evening nautical twilight starts"
                                            },
                                            "astroday" : false //during astronight
                                        },
                                        {
                                            "fname" : "nauticalDusk",
                                            "de" : {
                                                "name" : "nautische Abenddämmerung",
                                                "nxt" : "nächste",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Nautical dusk",
                                                "desc" : "evening astronomical twilight starts"
                                            },
                                            "astroday" : false //during astronight
                                        },
                                        {
                                            "fname" : "nadir",
                                            "de" : {
                                                "name" : "Nadir",
                                                "nxt" : "nächster",
                                                "desc" : "Fußpunkt gegenüber dem Zenit"
                                            },
                                            "en" : {
                                                "name" : "Nadir",
                                                "desc" : "darkest moment of the night, sun is in the lowest position"
                                            },
                                            "astroday" : false //during astronight
                                        },
                                        {
                                            "fname" : "nauticalDawn",
                                            "de" : {
                                                "name" : "nautische Morgendämmerung",
                                                "nxt" : "nächste",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "Nautical dawn",
                                                "desc" : "morning nautical twilight starts"
                                            },
                                            "astroday" : false //during astronight
                                        },
                                        {
                                            "fname" : "dawn",
                                            "de" : {
                                                "name" : "Morgendämmerung",
                                                "nxt" : "nächste",
                                                "desc" : ""
                                            },
                                            "en" : {
                                                "name" : "dawn",
                                                "desc" : "morning nautical twilight ends, morning civil twilight starts"
                                            },
                                            "astroday" : false //during astronight
                                        }
                                   
                                    ]
                                  };
                                   
                                  function writeAstroTimes(i) {
                                    // führende Nummer zur Sortierung in Admin/Objekte
                                    var nr = (i+1 < 10) ? "0" + (i+1) : (i+1);
                                    // Erstelle Objekt, falls nicht bereits vorhanden
                                    var idAstroObject = "javascript." + instance + "." + pfad + ".Zeiten." + nr + " - " + astrotime.elements[i].fname;
                                    createState(idAstroObject, " ", fC, {
                                        name: astrotime.elements[i].de.nxt + " " + astrotime.elements[i].de.name + " Uhrzeit",
                                        desc: astrotime.elements[i].en.desc,
                                        type: "string"
                                    });
                                   
                                    setTimeout(function() { // kurz warten, damit Objekte ggf. erst angelgt werden können
                                        var astrotag = getState(idAstrotag).val,
                                            temp;
                                        var today = new Date();
                                        var tomorrow = new Date(today.setDate(today.getDate()+1));
                                        var next_event;
                                        if (astrotag) { 
                                            // Wenn Tag (Aufgang vorbei (erst wieder morgen, Untergang kommt noch heute)
                                            next_event = (astrotime.elements[i].astroday) ? tomorrow : today; // prüfen
                                        } else { 
                                            // nach Nacht (Untergang vorbei (erst wieder morgen, Aufgang kommt heute oder morgen)
                                            next_event = (astrotime.elements[i].astroday) ? today : tomorrow; // prüfen
                                        }
                                        var fname = astrotime.elements[i].fname;
                                        temp = getAstroDate(fname, next_event);
                                        setState(idAstroObject, checkSec(temp.toLocaleTimeString('de-DE', { hour12: false })) );
                                    }, 3 * 1000);
                                  }
                                   
                                  // Zeit mit oder ohne Sekunden anzeigen
                                  function checkSec (zeit) {
                                    if (!sec) {
                                        var newString_arr = zeit.split(":");
                                        var newString = newString_arr[0] + ":" + newString_arr[1];
                                        return (newString);
                                    } else return (zeit);
                                  }
                                   
                                  function getAstroday() {
                                    // Astrotag bestimmen (boolean)
                                    createState(idAstrotag, false, fC, {
                                        type: "boolean",
                                        name: "Astrologischer Tag",
                                        desc: "Liegt die aktuelle Zeit zwischen Sonnenauf- und untergang"
                                    }); 
                                    setState(idAstrotag, isAstroDay());
                                  }
                                   
                                  function iterateAstrotimes() {
                                    // Zeiten für jede Astrozeit schreiben
                                    for (var i = 0; i < astrotime.elements.length; i++) {
                                        writeAstroTimes(i);
                                    }
                                  }
                                   
                                  // Astrotag checken
                                  schedule("*/1 * * * *", function () { // jede Minute
                                    getAstroday();
                                    iterateAstrotimes();
                                  });
                                   
                                  iterateAstrotimes();
                                  getAstroday();
                                  
                                  V Offline
                                  V Offline
                                  vsa
                                  schrieb am zuletzt editiert von
                                  #48

                                  @Malaus Vielen Dank schonmal.

                                  Ich habe das Skript eins-zu-eins neu angelegt unter Commons und als "Astro" gespeichert. Leider die gleiche Fehlermeldung. Ich habe ioBroker auf dem Raspberry laufen. JS Adapter 4.3.4 :-/

                                  vg

                                  M 1 Antwort Letzte Antwort
                                  0
                                  • V vsa

                                    @Malaus Vielen Dank schonmal.

                                    Ich habe das Skript eins-zu-eins neu angelegt unter Commons und als "Astro" gespeichert. Leider die gleiche Fehlermeldung. Ich habe ioBroker auf dem Raspberry laufen. JS Adapter 4.3.4 :-/

                                    vg

                                    M Offline
                                    M Offline
                                    Malaus
                                    schrieb am zuletzt editiert von
                                    #49

                                    @vsa ich auch.

                                    Wo genau zeigt er dir im Skript einen Fehler an?
                                    Bei mir gibts da zwei Stück, die man ignorieren kann. Einmal "setTimeout" und "next_event"

                                    1 Antwort Letzte Antwort
                                    0
                                    • V Offline
                                      V Offline
                                      vsa
                                      schrieb am zuletzt editiert von vsa
                                      #50

                                      @Malaus Hm.

                                      Im Javascript Editor unterhalb des Skripts:

                                      19:11:12.816	info	javascript.0 (15119) Start javascript script.js.common.Astro
                                      19:11:12.919	warn	javascript.0 (15119) at getAstroday (script.js.common.Astro:647:3)
                                      19:11:12.920	warn	javascript.0 (15119) at script.js.common.Astro:681:1
                                      19:11:12.922	info	javascript.0 (15119) script.js.common.Astro: registered 0 subscriptions and 11 schedules
                                      19:11:15.911	error	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:607:45)
                                      19:11:15.922	error	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:607:45)
                                      19:11:15.931	error	javascript.0 (15119) at Object.<anonymous> (script.js.common.Astro:607:45)
                                      

                                      Das geht dann alle 10 Sekunden so weiter.

                                      Zeile 607 (error) ist bei mir:
                                      setState(idAstroObject, checkSec(temp.toLocaleTimeString('de-DE', { hour12: false })) );
                                      das entspricht in deinem letzten geposteten Skript die letzte Zeile 304

                                      und Zeile 647 (warn):
                                      setState(idAstrotag, isAstroDay());
                                      das entspricht in deinem letzten geposteten Skript die letzte Zeile 324

                                      Zeile 681 (warn):
                                      getAstroday();
                                      das entspricht in deinem letzten geposteten Skript die letzte Zeile, also 341

                                      EDIT: Ich habs rausbekommen, die Geokoordinaten waren nicht eingetragen in den Adaptereinstellungen. Jetzt läuft das Skript....
                                      Vielen herzichen Dank für Deine Hilfe.

                                      1 Antwort Letzte Antwort
                                      0
                                      • V Offline
                                        V Offline
                                        vsa
                                        schrieb am zuletzt editiert von
                                        #51

                                        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 Antwort Letzte Antwort
                                        0
                                        • V vsa

                                          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 Offline
                                          M Offline
                                          Malaus
                                          schrieb am zuletzt editiert von
                                          #52

                                          @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 Antwort Letzte Antwort
                                          1
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          457

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe