NEWS
[Vorlage] LightControl
-
@schmakus sagte in [Vorlage] LightControl:
RampOff funktioniert auch nicht wie es soll. Die Lampen schalten nach dem Ramping oft nicht aus oder aus und wieder ein.
Joa, das is in dem Fall aber hausgemacht, weil Du auf 2sek runter bist. Bei 10Steps ist das ein Befehl alle 0,2 Sekunden, das klappt nich. Aber danke für den Hinweis, werd mal das minimum auf 5 Sek limitieren und hoffen dasses langt, wenn nicht dann 10sek.
Warnung im Log:
Hat keinerlei Auswirkungen, aber danke für die Meldung, wird in der nächsten Version gefixt sein.
-
kann man das ignorieren?
hab irgendwie gemerkt dass die lichtfarbe abends abrupt von (weis nicht genau wieviel Kelvin, gefühlt 4000K) auf 2100 wechselt. Als CtModus ist Solar gewählt-
-
@denis1988 sagte in [Vorlage] LightControl:
kann man das ignorieren?
Kommt drauf an. Wenn es im JS Adapter eingetragen ist, kannste ignorieren, ansonsten eintragen.
-
@Pittini neue Version V2.0.17 (09.12.2021) Erstmal danke für's mergen von dimmUp und dimmDown.
Aber nun ein Fehler:
Vermutlich keine Auswirkung auf's Script, aber solltest im Controller abfangen. Dort fehlt die Property "autoOnMotion.bri"
-
Guten Morgen,
herzlichen Dank für die Bereitstellung des Skriptes. Das scheint ganz viele meiner Anforderungen zu erfüllen und mir eine Menge an zusätzlichen Programmen zu ersparen.Mein erster Test mit nur einer Lampe hat aber leider einen Fehler gebracht.
const Version = "2.0.18" //vom 21.12.2021 - Skript um Lichter in Helligkeit, Farbe und Farbtemp global zu steuern - Git: https://github.com/Pittini/iobroker-LightControl - Forum: https://forum.iobroker.net/topic/36578/vorlage-lightcontrol log("starting LightControl V." + Version); const praefix = "0_userdata.0.LightControl2" // Skriptordner const LuxSensor = 'alias.0.Helligkeitssensoren.LUX_Dachboden.lux'; // Datenpunkt des globalen Luxsensors, wird verwendet wenn in der Gruppe kein gesonderter definiert wird const IsPresenceDp = ""; // Datenpunkt für Anwesenheit (true/false) const PresenceCountDp = "radar2.0._nHere"; // Datenpunkt für Anwesenheitszähler const logging = false; // Logging an/aus const RampSteps = 10; //Wieviele Schritte zum dimmen? Bitte nicht zu hoch setzen, wird zwar smoother, kann aber zu timing Problemen führen wenn gleichzeitig eine kurze Zeit in den Objekten gewählt. const minCt = 2700; //Regelbereich für Farbtemperatur in Kelvin für Adaptive Ct const maxCt = 6500;//Regelbereich für Farbtemperatur in Kelvin für Adaptive Ct const minBri = 10; //Mindesthelligkeit für AdaptiveBri const LightGroups = { 0: { description: "HWR", lights: { 0: { description: "Strahler1", power: { oid: "alias.0.Licht.HWRLichtDecke.SET", onVal: true, offVal: false }, }, }, sensors: { 0: { id: 'alias.0.Bewegungsmelder.BeWe_HWR.ACTUAL', motionVal: true, noMotionVal: false } } }, }; // ------------------ AB HIER NIX MEHR ÄNDERN --------------------------
javascript.4 2022-01-06 08:50:45.415 info script.js.Licht.LightControl2: SimpleGroupPowerOnOff: Normales ausschalten ohne Ramping für HWR javascript.4 2022-01-06 08:50:45.414 info script.js.Licht.LightControl2: Reaching GroupPowerOnOff for Group 0 (HWR), OnOff=false rampOn=false - {"enabled":false,"time":10,"switchOutletsLast":true} rampOff=false - {"enabled":false,"time":10,"switchOutletsLast":false} javascript.4 2022-01-06 08:50:45.414 info script.js.Licht.LightControl2: AutoOffTimed: Group 0 (HWR ) timed out, switching off. Motion=false javascript.4 2022-01-06 08:49:17.240 error at Controller (script.js.Licht.LightControl2:1121:17) javascript.4 2022-01-06 08:49:17.240 error at AutoOnMotion (script.js.Licht.LightControl2:939:15) javascript.4 2022-01-06 08:49:17.240 error at SetWhiteSubstituteColor (script.js.Licht.LightControl2:601:57) javascript.4 2022-01-06 08:49:17.240 error script.js.Licht.LightControl2: TypeError: Cannot read property 'oid' of undefined javascript.4 2022-01-06 08:49:17.237 info script.js.Licht.LightControl2: SimpleGroupPowerOnOff: Normales anschalten ohne Ramping für HWR javascript.4 2022-01-06 08:49:17.237 info script.js.Licht.LightControl2: Reaching GroupPowerOnOff for Group 0 (HWR), OnOff=true rampOn=false - {"enabled":false,"time":10,"switchOutletsLast":true} rampOff=false - {"enabled":false,"time":10,"switchOutletsLast":false} javascript.4 2022-01-06 08:49:17.237 info script.js.Licht.LightControl2: Motion for Group 0 (HWR ) detected, switching on javascript.4 2022-01-06 08:48:45.414 info script.js.Licht.LightControl2: AutoOffTimed: Motion detected, restarting Timeout for Group 0 set time=120
Die Lampe ist eine ganz normale Lampe ohne Dimmer oder Farbe. Einfach nur AN oder AUS.
Ein ähnlicher Fehler wie --> script.js.Licht.LightControl2: TypeError: Cannot read property 'oid' of undefined
wurde weiter oben schon beschrieben. Habe dort aber keine Lösung zu gefunden.
Würde gerne das Skript nutzen und hoffe das dieser Fehler behoben werden kann. Wenn ich da etwas weiter unterstützen kann, mache ich das gerne.Jetzt schon mal herzlichen Dank und viele Grüße
Dirk -
@dirk Ja is klar dass da Fehler kommen, Du hast ja nach power alles gelöscht statt nur oid leerzu lassen. Das kann so nicht gehen. Hier mal ein Beispiel (was in der Basiskonfig eigentlich ja schon drin ist, hättest nur abkupfern müssen) für sone Ein/Aus Lampe:
2: { description: "Stehlampe Couch", power: { oid: "sonoff.0.Sonoff20.POWER", onVal: true, offVal: false }, bri: { oid: "", minVal: null, maxVal: null, defaultVal: null }, ct: { oid: "", minVal: null, maxVal: null }, sat: { oid: "", minVal: null, maxVal: null }, modeswitch: { oid: "", whiteModeVal: false, colorModeVal: true }, color: { oid: "", type: "", default: "" } },
-
@pittini sagte in [Vorlage] LightControl:
@dirk Ja is klar dass da Fehler kommen, Du hast ja nach power alles gelöscht statt nur oid leerzu lassen. Das kann so nicht gehen. Hier mal ein Beispiel (was in der Basiskonfig eigentlich ja schon drin ist, hättest nur abkupfern müssen) für sone Ein/Aus Lampe:
2: { description: "Stehlampe Couch", power: { oid: "sonoff.0.Sonoff20.POWER", onVal: true, offVal: false }, bri: { oid: "", minVal: null, maxVal: null, defaultVal: null }, ct: { oid: "", minVal: null, maxVal: null }, sat: { oid: "", minVal: null, maxVal: null }, modeswitch: { oid: "", whiteModeVal: false, colorModeVal: true }, color: { oid: "", type: "", default: "" } },
Alles Klar --> Sorry da habe ich die Beispiele nicht gründlich genug durchgeschaut und mich von diesem Satz aus der Doku --> Nachdem ihr das Skript in ein neues Js Projekt kopiert habt, müßt ihr dem Skript Eure Leuchtmittel bekannt machen, es wird mindestens ein Schaltdatenpunkt (an/aus) erwartet. <-- verwirren lassen.
Ich ändere das und teste weiter.
Danke für die schnelle Antwort
Dirk -
Vielen Dank für dieses tolle Skript. Leider habe ich ein paar Probleme damit:
2022-01-18 23:32:43.694 - info: javascript.0 (32839) script.js.common.Licht.LightControl: adaptiveCtLinear=0 adaptiveCtSolar=0 adaptiveCtSolarInterpolated=0 adaptiveCtTimed=0 2022-01-18 23:32:50.285 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Triggered linked Sensor mihome.0.devices.sensor_motion_aq2_158d0004aca6b9.state new value is true 2022-01-18 23:32:50.286 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Reaching SummarizeSensors, Group=0 2022-01-18 23:32:50.286 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Gruppe=0 Sensor 2 with target mihome.0.devices.sensor_motion_aq2_158d0004aca6b9.state has value true 2022-01-18 23:32:50.287 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Summarized IsMotion for Group 0 = true 2022-01-18 23:32:50.287 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Reaching Controller, Group=0 Property1=isMotion NewVal=true OldVal=false 2022-01-18 23:32:50.287 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Motion for Group 0 (Flur ) detected, switching on 2022-01-18 23:32:50.288 - info: javascript.0 (32839) script.js.common.Licht.LightControl: Reaching GroupPowerOnOff for Group 0 (Flur), OnOff=true rampOn=false - {"enabled":false,"time":10,"switchOutletsLast":true} rampOff=false - {"enabled":false,"time":10,"switchOutletsLast":false} 2022-01-18 23:32:50.288 - info: javascript.0 (32839) script.js.common.Licht.LightControl: SimpleGroupPowerOnOff: Normales anschalten ohne Ramping für Flur 2022-01-18 23:32:50.312 - error: javascript.0 (32839) script.js.common.Licht.LightControl: TypeError: Cannot read property 'val' of null 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at SimpleGroupPowerOnOff (script.js.common.Licht.LightControl:707:83) 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at GroupPowerOnOff (script.js.common.Licht.LightControl:736:9) 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at AutoOnMotion (script.js.common.Licht.LightControl:965:9) 2022-01-18 23:32:50.316 - error: javascript.0 (32839) at Controller (script.js.common.Licht.LightControl:1166:17)
Ich kann die Fehlermeldungen nicht nachvollziehen und würde mich freuen, wenn mir jemand dabei helfen könnte.
Ich habe lediglich zwei Shelly Dimmer und drei mihome BWM in Betrieb:const praefix = "0_userdata.0.LightControl2" // Skriptordner const LuxSensor = 'wiffi-wz.0.root.192_168_1_155.w_lux'; // Datenpunkt des globalen Luxsensors, wird verwendet wenn in der Gruppe kein gesonderter definiert wird const IsPresenceDp = ""; // Datenpunkt für Anwesenheit (true/false) const PresenceCountDp = ""; // Datenpunkt für Anwesenheitszähler const logging = true; // Logging an/aus const RampSteps = 10; //Wieviele Schritte zum dimmen? Bitte nicht zu hoch setzen, wird zwar smoother, kann aber zu timing Problemen führen wenn gleichzeitig eine kurze Zeit in den Objekten gewählt. const minCt = 2700; //Regelbereich für Farbtemperatur in Kelvin für Adaptive Ct const maxCt = 6500;//Regelbereich für Farbtemperatur in Kelvin für Adaptive Ct const minBri = 10; //Mindesthelligkeit für AdaptiveBri const LightGroups = { 0: { description: "Flur", lights: { 0: { description: "StrahlerOG1", power: { oid: "shelly.0.SHDM-2#C45BBE5645E3#1.lights.Switch", onVal: true, offVal: false }, bri: { oid: "shelly.0.SHDM-2#C45BBE5645E3#1.lights.brightness", minVal: 0, maxVal: 100, defaultVal: 100 }, ct: { oid: "", minVal: null, maxVal: null }, sat: { oid: "", minVal: null, maxVal: null }, modeswitch: { oid: "", whiteModeVal: false, colorModeVal: true }, color: { oid: "", type: "", default: "" } }, 1: { description: "StrahlerEG", power: { oid: "shelly.0.SHDM-2#E0980694DB0C#1.lights.Switch", onVal: true, offVal: false }, bri: { oid: "shelly.0.SHDM-2#E0980694DB0C#1.lights.brightness", minVal: 0, maxVal: 100, defaultVal: 100 }, ct: { oid: "", minVal: null, maxVal: null }, sat: { oid: "", minVal: null, maxVal: null }, modeswitch: { oid: "", whiteModeVal: false, colorModeVal: true }, color: { oid: "", type: "", default: "" } }, }, sensors: { 0: { id: 'mihome.0.devices.sensor_motion_aq2_158d0002ea1b58.state', motionVal: true, noMotionVal: false }, 1: { id: 'mihome.0.devices.sensor_motion_aq2_158d0002ebffca.state', motionVal: true, noMotionVal: false }, 2: { id: 'mihome.0.devices.sensor_motion_aq2_158d0004aca6b9.state', motionVal: true, noMotionVal: false } } }, };
folgend noch das vollständige Skript:
-
@passuff Zeig mal die Datenpunkte "Switch" von deinen 2 Shelly Dimmern.
-
@schmakus sagte in [Vorlage] LightControl:
@passuff Zeig mal die Datenpunkte "Switch" von deinen 2 Shelly Dimmern.
{ "type": "state", "common": { "type": "boolean", "read": true, "write": true, "name": "Switch", "role": "switch", "def": false }, "native": {}, "from": "system.adapter.shelly.0", "user": "system.user.admin", "ts": 1641885787418, "_id": "shelly.0.SHDM-2#C45BBE5645E3#1.lights.Switch", "acl": { "object": 0, "state": 0, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
-
Hallo, ich habe das Skript erfolgreich eingefügt und meine Lampen eingetragen. Es funktioniert alles super BWM etc. funktioniert alles. Mir ist aber eine Sache aufgefallen, wenn ich über Google Home sage: Wohnzimmer Decke auf 80% dann wird zwar der Wert bei bri geändert aber die Lampen gehen nicht mit an. Sonst (vor dem Skript) war es so, dass das Licht bei bri Änderung angegangen ist. Gibt es da eine Funktion in dem Skript? Jetzt muss ich immer zwei Befehle absetzen, einmal Lichthelligkeit und Licht anschalten.
-
@kilian-z Its not a bug, its a feature. Hintergrund ist der, das bei der adaptiven Helligkeit, permanent die Helligkeit gesetzt wird damit das beim einschalten passt. Und wäre es so, wie Du es gern hättest, dann würde alle paar Sekunden das Licht angehen ;).
-
-
@kilian-z said in [Vorlage] LightControl:
@pittini Danke @pittini. Ja das macht Sinn. Nutze bis jetzt noch nicht die adaptive Helligkeit.
Du vielleicht nicht, aber das Script intern.
Wie hast du GoogleHome eingebunden? Per iot? Wenn ja, einfach beide Datenpunkte, Power und Bri als ein Gerät anlegen. -
@schmakus Danke für die Antwort. Ich habe alle drei Datenpunkte in einem Gerät über iot eingebunden.
-
@Pittini Die Fehlermeldung im log von @passuff deutet doch darauf hin, dass der Wert des Switch nicht gelesen werden kann, weil entweder kein Wert vorhanden ist, oder der Pfad zum DP nicht stimmt, oder?
2022-01-18 23:32:50.312 - error: javascript.0 (32839) script.js.common.Licht.LightControl: TypeError: Cannot read property 'val' of null 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at SimpleGroupPowerOnOff (script.js.common.Licht.LightControl:707:83) 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at GroupPowerOnOff (script.js.common.Licht.LightControl:736:9) 2022-01-18 23:32:50.315 - error: javascript.0 (32839) at AutoOnMotion (script.js.common.Licht.LightControl:965:9) 2022-01-18 23:32:50.316 - error: javascript.0 (32839) at Controller (script.js.common.Licht.LightControl:1166:17)
-
@kilian-z said in [Vorlage] LightControl:
@schmakus Danke für die Antwort. Ich habe alle drei Datenpunkte in einem Gerät über iot eingebunden.
Ich habe immer Power, Bri, ct und color eingebunden.
-
@schmakus Du musst aber trotzdem zwei Befehle absenden oder? Wenn Lampe aus ist: Helligkeit einstellen und dann Lampe anschalten. Habe ich das richtig verstanden?
-
In deinem Skript muss ein Datenpunkt mit einer Anzahl an anwesenden Personen angegeben werden. Darf ich fragen wofür er benötigt wird? Ich habe tatsächlich keinen Datenpunkt, da ich auch andere Geräte auf Presence checke...
-
@kilian-z said in [Vorlage] LightControl:
@schmakus Du musst aber trotzdem zwei Befehle absenden oder? Wenn Lampe aus ist: Helligkeit einstellen und dann Lampe anschalten. Habe ich das richtig verstanden?
Genau. Beim schalten per "power" Datenpunkt wird die Helligkeit, welche zuvor bei "bri" gesetzt ist an die Lampe gesendet.