NEWS
[Gelöst] Auf Sonnenstand reagieren mit beschreibbarer Variable
-
createState('javascript.0.Zeiten.Treppenlicht.Elevation', -0.5 , {type:"number", role:"javascript"}); var idt3 = 'javascript.0.Zeiten.Treppenlicht.Elevation'; var idElevation = getState(idt3).val; on({ id: "javascript.0.Global.Sonnenstand.Elevation"/*Global.Sonnenstand.Elevation*/, change: "ne", valLe: idElevation, oldValGt: idElevation, logic: "and" }, function (obj) { Treppenlicht_an_Sonnenuntergang(); }); function Treppenlicht_an_Sonnenuntergang() { if (getState("radar.0.G-Tag-Claudia.here"/*G-Tag-Claudia.here*/).val === false && getState("radar.0.G-Tag-Sebastian.here"/*G-Tag-Sebastian.here*/).val === false ) { return; } if (getState("knx.0.Licht.Licht-Status.OG-Schlafzimmer-Treppenleuchte-Schalten-Status"/*OG-Schlafzimmer-Treppenleuchte-Schalten-Status*/).val === 1) { return; } event("Schlafzimmer...Treppenbeleuchtung zum Sonnenuntergang eingeschalten","Allgemein","white"); setState ("knx.0.Licht.Licht-Schalten.OG-Schlafzimmer-Treppenleuchte-Schalten"/*OG-Schlafzimmer-Treppenleuchte-Schalten*/, 1); }
Wie schon erwähnt ... Typ String und alles lief.
Sebastian
-
@webseb79 sagte:
Wie schon erwähnt ... Typ String und alles lief.
Ein Stringvergleich (im Trigger) dürfte Probleme machen (bei negativen Werten).
-
@paul53
Zu dem Zeitpunkt war der Sonnenstand ja positiv...also kannst du rechthaben.
Das Script läuft ja schon einige Zeit, nur 2 Dinge wurden verändertvalLe: -0.5, oldValGt: -0.5, auf valLe: idElevation, oldValGt: idElevation,
Wie kann ich die feste vergebene Zahl nun flexibel über Vis steuern?
-
@webseb79 sagte:
Wie kann ich die feste vergebene Zahl nun flexibel über Vis steuern?
Zusätzlich:
on(idt3, function(dp) { idElevation = dp.state.val; });
-
Da bin ich jetzt überfragt wohin das noch soll.
Deine on - Anweisung sagt doch nur das wenn sich idt3 ändert dieser Wert in idElevation geschoben wird , oder?
Ich triggere doch auf den ständig veränderten Sonnenstand.Sebastian
-
@webseb79 sagte:
das wenn sich idt3 ändert dieser Wert in idElevation geschoben wird , oder?
Richtig. Das genau wolltest Du doch: Wenn der Wert in Vis geändert wird, kommt diese Änderung auch im Skript an, ohne dass das Skript neu gestartet werden muss.
-
Deine letzte Anweisung
on(idt3, function(dp) { idElevation = dp.state.val; });
hatte ich vorhin noch nicht und dort ging es doch schon wie ich es wollte , halt nur mit dem Datentyp "String" als Variable von Vis kommend und vergleichend vom Sonnenstandsscript die Variable kommend auch als "String".
Nur dann kam doch die Meldung vom Sonnenstandsscript das es ein Datentyp "Number" verlangt. -
@webseb79 sagte:
hatte ich vorhin noch nicht und dort ging es doch schon wie ich es wollte
Ohne den Trigger wird der Wert nur bei Skriptstart aktualisiert und bleibt dann konstant, egal was in Vis geändert wird.
-
@paul53
Ok ... zum laufen bekomme ich das nicht.
Gibt es eine andere Variante um zum Ziel zu kommen?
Eine angelegte Variable in Instanz.0 durch Vis beschreibbar vergleicht den Elevation Wert des Sonnenstandes und löst eine Funktion aus beim unterschreiten als 1.Beispiel und beim Überschreiten als 2.Beispiel.
Hast du da eine Idee Paul53Danke Sebastian
-
Vorschlag:
const idGrenzwert = 'javascript.0.Zeiten.Treppenlicht.Elevation'; const idElevation = "javascript.0.Global.Sonnenstand.Elevation"/*Global.Sonnenstand.Elevation*/; createState(idGrenzwert, -0.5, {type: 'number', unit: '°'}); var gwElevation = parseFloat(getState(idGrenzwert).val); on(idGrenzwert, function(dp) { gwElevation = parseFloat(dp.state.val); }); on(idElevation, function(dp) { if(dp.state.val <= gwElevation && dp.oldState.val > gwElevation) { // Aktion bei Unterschreiten Grenzwert } if(dp.state.val >= gwElevation && dp.oldState.val < gwElevation) { // Aktion bei Überschreiten Grenzwert } });
-
Vielen Dank Paul53 !
Ich glaube wir hätten die ganze Sache schon viel früher lösen können mit deinem Vorschlag.
Ich muss auch sagen das du richtig gut im Stoff stehst was Javascript angeht.
Ich lese ja ziemlich viel hier mit Tag täglich und du bist eigentlich bei vielen Lösungen mit present.
Mach weiter so.Danke
Sebastian
-
@webseb79 sagte:
Ich glaube wir hätten die ganze Sache schon viel früher lösen können mit deinem Vorschlag.
Das Sonnenstandsskript musste auch für den richtigen Datenpunkttyp korrigiert werden.