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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.1k

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.4k

Dynamisches Licht - Farbverlauf Tag/Nacht

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascripttemplate
104 Beiträge 13 Kommentatoren 18.2k 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.
  • 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
            • V Offline
              V Offline
              vsa
              schrieb am zuletzt editiert von vsa
              #53

              @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 Antwort Letzte Antwort
              0
              • V 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 Offline
                M Offline
                Malaus
                schrieb am zuletzt editiert von
                #54

                @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 Antwort Letzte Antwort
                1
                • M Malaus

                  @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 Offline
                  V Offline
                  vsa
                  schrieb am zuletzt editiert von vsa
                  #55

                  @Malaus danke, mach ich. Ich suchte schon nach Sunset ;-)

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

                    @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 Antwort Letzte Antwort
                    1
                    • V Offline
                      V Offline
                      vsa
                      schrieb am zuletzt editiert von
                      #57

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

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

                        @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 Antwort Letzte Antwort
                        1
                        • V Offline
                          V Offline
                          vsa
                          schrieb am zuletzt editiert von
                          #59

                          @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 Antwort Letzte Antwort
                          0
                          • V Offline
                            V Offline
                            vsa
                            schrieb am zuletzt editiert von
                            #60

                            ... sorrry nocheinmal...

                            nur die logs laufen mit warn voll:

                            Unbenannt.JPG

                            vg

                            M 1 Antwort Letzte Antwort
                            0
                            • V vsa

                              ... sorrry nocheinmal...

                              nur die logs laufen mit warn voll:

                              Unbenannt.JPG

                              vg

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

                              @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 Antwort Letzte Antwort
                              1
                              • V Offline
                                V Offline
                                vsa
                                schrieb am zuletzt editiert von
                                #62

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

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

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

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

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

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

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

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

                                        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 Antwort Letzte Antwort
                                        0
                                        • V Offline
                                          V Offline
                                          vsa
                                          schrieb am zuletzt editiert von
                                          #67

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          834

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          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