NEWS
Bei Filmstart Tradfri runterdimmer
-
Hallo liebe Gemeinde,
ich habe mir gerade ioBroker installiert und bin absolut begeistert wie einfach die Einrichtung ist.
Nun habe ich direkt auch eine Frage
Ist es möglich bei der Wiedergabe eines Filmes über Kodi, ein Tradfri Leuchtmittel runter zu dimmen?
Vielen dank schon mal für eure Antworten.
Gruß Marcel
-
Hallo liebe Gemeinde,
ich habe mir gerade ioBroker installiert und bin absolut begeistert wie einfach die Einrichtung ist.
Nun habe ich direkt auch eine Frage
Ist es möglich bei der Wiedergabe eines Filmes über Kodi, ein Tradfri Leuchtmittel runter zu dimmen?
Vielen dank schon mal für eure Antworten.
Gruß Marcel ` Das ist natürlich möglich. Hast du einen Datenpunkt bei kodi ein Film läuft? Das kannst du über den scenen Adapter machen oder ein kleines einfaches Script im Javascript Adapter endweder mit Blocky oder js Script. Aber das einfachste ist der scenen Adapter. Wenn du etwas umfangreicher schalten willst mit mehr Logiken empfehle ich dir den Javascript Adapter. Da sind die Möglichkeiten nahezu grenzenlos
Gesendet von meinem Handy
-
Ich habe leider überhaupt keine Programmierkenntnisse, deswegen wird es auf die Szenen hinauslaufen.
Ich habe auch schon mal angefangen mir was zu basteln, ich weiß allerdings nicht ob das so funktionieren würde.
Die states für Play, Pause und Stop lassen sich in Kodi auslesen.
Jetzt soll die lightbulb bei Play auf 0% gedimmt werden und bei Pause oder Stop wieder auf 100%.
-
Ich habe auch schon mal angefangen mir was zu basteln, ich weiß allerdings nicht ob das so funktionieren würde. `
Na dann poste mal was du hast, sodass wir drüberschauen können -
Ich habe mir eine Szene FilmStart angelegt und dort 2 Zustände hinzugefügt.
-
kodi.0.state (Play, stop or pause)
-
tradfri.0.***.lightbulb.brightness (254-0)
Wie funktioniert das ganze nun das wenn beim state "Play" erkannt wird, dass brightness auf 0 gestellt wird und bei "stop oder pause" auf 254.
Bei "Setzen bei False" habe ich den Haken gesetzt.
Ich bin da noch nicht ganz durchgestiegen.
3473_iobroker.png -
-
Ne so wird das nix. Die Szene schaltet die hinterlegten Zustände, wenn der State der Szene (scene.0.szenenname) auf true/false gesetzt wird. Dein Auslöser ist komplizierter, d.h. du brauchst ein Skript. Ist aber nicht schwer, keine Sorge, bitte nur mal die Schreibweisen (groß/klein, etc…) überprüfen!
on("kodi.0.state", function (obj) { switch (obj.state.val) { case "play": setState("tradfri.0.***.lightbulb.brightness", 0); break; case "pause": case "stop": setState("tradfri.0.***.lightbulb.brightness", 254); break; } });
-
Ich habe das Skript angelegt und nach meinem ermessen abgeändert.
Leider funktioniert es nicht.
on("kodi.0.state", function (obj) { switch (obj.state.val) { case "Play": setState("tradfri.0.L-65537.lightbulb.brightness", 0); break; case "pause": case "stop": setState("tradfri.0.L-65537.lightbulb.brightness", 254); break; } });
-
Leider funktioniert es nicht. `
Meine Lieblings-FehlermeldungGibts nen Fehler im Log? Hast du das Skript auch nicht unter global abgelegt?
Ansonsten füge mal ein paar Logs ein, um zu sehen ob es überhaupt richtig ausgeführt wird:
on("kodi.0.state", function (obj) { log("State geändert: " + obj.state.val); switch (obj.state.val) { case "Play": log("Video läuft, schalte Licht aus..."); setState("tradfri.0.L-65537.lightbulb.brightness", 0); break; case "pause": case "stop": log("Video läuft nicht, schalte Licht an..."); setState("tradfri.0.L-65537.lightbulb.brightness", 254); break; } });
-
Das Skript ist nicht unter "Global" abgelegt. Es hat auch keinen eigenen Ordner.
Das einzige was im Log steht ist folgendes:
19:29:59.394 [info] javascript.0 Start javascript script.js.Filmstart_dimmen 19:29:59.395 [info] javascript.0 script.js.Filmstart_dimmen: subscribe: {"pattern":{"id":"kodi.0.state","change":"ne"},"name":"script.js.Filmstart_dimmen"} 19:29:59.395 [info] javascript.0 script.js.Filmstart_dimmen: subscribe: {"pattern":{"id":"kodi.0.state","change":"ne"},"name":"script.js.Filmstart_dimmen"} 19:29:59.395 [info] javascript.0 script.js.Filmstart_dimmen: registered 2 subscriptions and 0 schedules
Tut mir leid, ich habe wirklich keine Ahnung vom Programmieren.
-
19:29:59.395 [info] javascript.0 script.js.Filmstart_dimmen: subscribe: {"pattern":{"id":"kodi.0.state","change":"ne"},"name":"script.js.Filmstart_dimmen"}
19:29:59.395 [info] javascript.0 script.js.Filmstart_dimmen: subscribe: {"pattern":{"id":"kodi.0.state","change":"ne"},"name":"script.js.Filmstart_dimmen"} `
Hast du jetzt beide Funktionen drin? Die letzte sollte reichen.Dass da sonst nix im Log passiert, lässt mich vermuten dass der Trigger nicht ausgelöst wird. Magste mal nen Screenshot von den Objekten unter "kodi.0" machen? Am besten mal, wenn ein Video läuft und wenn nicht.
-
Ich habe jetzt mal ein wenig rumprobiert und jetzt funktioniert es.
Allerdings kann ich die Lampen nur ein- und ausschalten.
So funktioniert es erstmal:
on("kodi.0.state", function (obj) { log("State geändert: " + obj.state.val); switch (obj.state.val) { case "play": log("Video läuft, schalte Licht aus..."); setState("tradfri.0.L-65537.lightbulb.state"/*on/off*/, false); break; case "pause": case "stop": log("Video läuft nicht, schalte Licht an..."); setState("tradfri.0.L-65537.lightbulb.state"/*on/off*/, true); break; } });
Die Lampen faden ja zum Glück etwas. Schöner wäre es natürlich wenn man den Dimmvorgang schön langsam einstellen könnte.
Kann man auch noch eine Variable einbauen, wo erkannt wird ob die Lampe vorher eingeschaltet war oder nicht?
Gruß Marcel
-
Die Lampen faden ja zum Glück etwas. Schöner wäre es natürlich wenn man den Dimmvorgang schön langsam einstellen könnte. `
Werde ich demnächst mal einbauen.Allerdings kann ich die Lampen nur ein- und ausschalten. `
Das ist komisch, brightness > 0 sollte eigentlich auch anschalten.Kann man auch noch eine Variable einbauen, wo erkannt wird ob die Lampe vorher eingeschaltet war oder nicht? `
Bin zwar nicht ganz sicher, ob das das ist was du damit bezwecken willst, aber probiers mal so:var idStatus = "tradfri.0.L-65537.lightbulb.state"; // Auf Status der Lampe lauschen var status = getState(idStatus); on(idStatus, function (obj) { status = obj.state.val }); on("kodi.0.state", function (obj) { log("State geändert: " + obj.state.val); switch (obj.state.val) { case "play": if (status) { log("Video läuft, schalte Licht aus..."); setState(idStatus, false); } else { log("Video läuft, Licht ist bereits aus"); } break; case "pause": case "stop": if (!status) { log("Video läuft nicht, schalte Licht an..."); setState(idStatus, true); } else { log("Video läuft nicht, Licht ist bereits an"); } break; } });
-
Das ganze soll bezwecken, dass wenn die Lampe bei Filmstart aus war, die Lampe nach Filmende dann nicht eingeschaltet wird.
Vielen Dank für deine Mühe und das du sogar auf meine Wünsche eingehst und diese mit einbauen willst!
Ich probiere das neue Skript morgen mal aus und werde dann berichten.
-
Das ganze soll bezwecken, dass wenn die Lampe bei Filmstart aus war, die Lampe nach Filmende dann nicht eingeschaltet wird. `
Aaah, dann muss das anders lauten.var idStatus = "tradfri.0.L-65537.lightbulb.state"; var statusBeiStart; on("kodi.0.state", function (obj) { log("State geändert: " + obj.state.val); switch (obj.state.val) { case "play": statusBeiStart = getState(idStatus).val; log("Video läuft, schalte Licht aus..."); setState(idStatus, false); break; case "pause": case "stop": log("Video läuft nicht mehr, stelle Status wieder her..."); setState(idStatus, statusBeiStart); break; } });
-
Ich bin leider erst gestern Abend zum testen gekommen.
Aber es funktioniert fast so wie ich es mir vorstelle.
Wenn man jetzt noch die Dimmgeschwindigkeit regeln könnte, wäre es absolut perfekt.
Danke!!!
-
Wenn man jetzt noch die Dimmgeschwindigkeit regeln könnte, wäre es absolut perfekt. `
Steht auf der TODO-Liste, kommt in Kürze:transitionTime: 5, // TODO: <- make this configurable
-
Geht jetzt auch (teilweise): http://forum.iobroker.net/viewtopic.php?p=86551#p86551
Nur scheint on/off den Wert zu ignorieren. Du könntest jedoch schummeln:
an: transitionTime => Wunschdauer, Brightness => 254
aus: transitionTime => Wunschdauer X, Brightness => 1. nach X sekunden: on/off => false
-
Ich habe heute Mittag das Skript nochmal getestet.
Die Lampe schaltet sich nach dem Film ein obwohl der Status vorher aus war.
Wie genau muss das Skript denn mit der transitiontime aussehen?
Ich weiß leider nicht wo ich das einbauen muss.
Danke fürs helfen und dafür das du die transitiontime mit einprogrammiert hast.
-
Die Lampe schaltet sich nach dem Film ein obwohl der Status vorher aus war. `
Habe die Logausgabe mal ergänzt, was zeigt der Log an bei folgendem Skript?! ````
var idStatus = "tradfri.0.L-65537.lightbulb.state";
! var statusBeiStart;
! on("kodi.0.state", function (obj) {
log("State geändert: " + obj.state.val);
switch (obj.state.val) {
case "play":
statusBeiStart = getState(idStatus).val;
log("Video läuft, schalte Licht aus... Licht war " + (statusBeiStart ? "an" : "aus"));
setState(idStatus, false);
break;
! case "pause":
case "stop":
log("Video läuft nicht mehr, stelle Status <" + (statusBeiStart ? "an" : "aus") + "> wieder her...");
setState(idStatus, statusBeiStart);
break;
}
});Ein Versuch mit TransitionTime könnte wie folgt aussehen (ungetestet): >! ```` var idStatus = "tradfri.0.L-65537.lightbulb.state"; var idTime = "tradfri.0.L-65537.lightbulb.transitionDuration"; var idBrightness = "tradfri.0.L-65537.lightbulb.brightness"; >! var transitionTime = 2; // Zeit in Sekunden >! var statusBeiStart; >! function an() { setState(idTime, transitionTime); // Dimm-Dauer festlegen setState(idBrightness, 254); // maximale Helligkeit ansteuern } function aus() { setState(idTime, transitionTime); // Dimm-Dauer festlegen setState(idBrightness, 1); // minimale Helligkeit ansteuern setStateDelayed(idStatus, false, transitionTime*1000) // <transitiontime>sek später komplett abschalten } >! on("kodi.0.state", function (obj) { log("State geändert: " + obj.state.val); switch (obj.state.val) { case "play": statusBeiStart = getState(idStatus).val; log("Video läuft, schalte Licht aus... Licht war " + (statusBeiStart ? "an" : "aus")); if (statusBeiStart) aus(); break; >! case "pause": case "stop": log("Video läuft nicht mehr, stelle Status <" + (statusBeiStart ? "an" : "aus") + "> wieder her..."); >! if (statusBeiStart) an(); else aus(); >! break; } });</transitiontime>
Edit: Fehlerkorrektur
-
Und..erfolgreich getestet??