NEWS
[gelöst] Blockly Licht über Bewegungsmelder, Dauerlicht über Taster
-
Kann ich nochmal ein paar blöde Fragen stellen, wenn ich nicht weiter komme? `
Na klar…"Hier werden Sie geholfen...."Grüße
PS.
Setzte mal in den Betreff Deines ersten Beitrages "[Frage] Blockly Licht über…...." rein.
Da reagieren auch noch ein paar andere Blockly-Scriptler.
-
Moin allerseits,
da bin ich wieder :-). Ich habe mal was zusammengeklickt, rein zum Verständnis für mich und verstehe es nicht.
Variablen alle auf 0, Trigger absichtlich nur auf Bewegung, d.h. für mein Verständnis, Taster werden erst ausgewertet, wenn vorher Bewegung war.
Jetzt kommt Bewegung, und NUR Bewegung, trotzdem wird einer der Taster ausgelöst. Es sollte doch so sein, dass der Bewegungsmelder triggert, es wird geschaut ob der Taster oben gedrückt ist -> nein -> Taster unten gedrückt? -> nein -> Ende, auf den nächsten Trigger warten.
~~http://up.picr.de/29825175bh.png" />
http://up.picr.de/29825182wy.png" />~~ -
Dem Datenpunkt (Taster….PRESS_SHORT) ist dein Skript vollkommen egal. Er weiß nichts davon, wann dein Skript startet, stoppt, oder wann du ihn in deinem Skript abfragst. Der bekommt bei Betätigung einen Wert. Wenn du denSchalter also vorher mal betätigt hast und damit der Datenpunkt-Wert auf true steht, wird die Abfrage in deinem Skript auch bei der Ausführung sofort reagieren.
Wie du damit umgehst, hängt jetzt natürlich davon ab, wie sich bei Betätigung die States (Datenpunkte) ändern. Am besten schaust du dir mal genau an, was bei welchem Tastendruck passiert (welcher Datenpunkt in welchem Zustand welchen Wert hat) und überlegst dann, wie das Skript strukturiert sein muss.
Prinzipiell würde ich bei deinem ersten Skript anfangen und die Trigger trennen, d.h. einen für jeden Datenpunkt ohne diese 3fach-Wenn-Dann-Abfrage. Interaktion dazwischen läuft dann am besten über extra Skript-Variablen (z.b. für manuellen Modus an/aus) oder (wenn das logisch funktioniert) durch Abfrage der Lichtschalter-Zustände im Bewegungs-Trigger.
-
Hi,
habe es mal kurz überflogen.
Du triggerst den BM auf "Aktualisierung"
HM Aktoren werden häufig aktualisiert, auch ohne Zustandsänderung!
Da rennt Dein Trigger immer los.
Besser ist auf "wurde geändert".
Aber auch da aufpassen.
MOTION ändert sich auf TRUE wenn Bewegung erkannt
und dann wieder auf FALSE wenn keine Bewegung erkannt.
Wenn Du auf beide Zustände reagieren willst, musst Du den BM Zustand innerhalb des Triggers abfragen.
Falls BM = wahr
mache …...
sonst .......
Oder Du stellt den Trigger auf WAHR.
Dann rennt er nur los wenn der BM Bewegung erkennt.
Dir ist auch bewust, dass die Blöcke ausserhalb des Triggers NUR EINMALIG bei Scriptstart ausgeführt werden?
Grüße
-
Dem Datenpunkt (Taster….PRESS_SHORT) ist dein Skript vollkommen egal. Er weiß nichts davon, wann dein Skript startet, stoppt, oder wann du ihn in deinem Skript abfragst. Der bekommt bei Betätigung einen Wert. Wenn du denSchalter also vorher mal betätigt hast und damit der Datenpunkt-Wert auf true steht, wird die Abfrage in deinem Skript auch bei der Ausführung sofort reagieren. `
Soweit wie AlCalzone hatte ich gar nicht gelesen. :roll:Er hat natürlich vollkommen recht.
Grüße
-
@Alcalzone: Ich hatte auch den Verdacht, das die Variable vom Taster vielleicht auf true steht, deswegen am Anfang des Scriptes das Setzen aller Variablen auf false. Aber auch nach dem Neustart des Scriptes hat sich das Verhalten nicht geändert.
@rantanplan: ich habe die Blöcke absichtlich außerhalb gelegt, weil ich ja nicht möchte, dass bei jedem Trigger die Variablen wieder auf 0 stehen. Auf beide Zustände möchte ich nicht triggern, da die Zeit, die dann ablaufen soll, immer 2x gestartet wird. Das die Homematic auch mal so aktualisiert wusste ich nicht und würde vielleicht auch erklären, warum nach 15s nochmal getriggert wurde.
Ich werde weiter testen und bin froh, Euch löchern zu können
-
@rantanplan: ich habe die Blöcke absichtlich außerhalb gelegt, weil ich ja nicht möchte, dass bei jedem Trigger die Variablen wieder auf 0 stehen. Auf beide Zustände möchte ich nicht triggern, da die Zeit, die dann ablaufen soll, immer 2x gestartet wird. `
Warum soll die Zeit dann 2x gestartet werden?Dafür gibt es ja die Bedingungsabfragen.
Mal sehen, ob ich Dein Problem richtig verstehe.
1. es gibt KEINE Direktverknüpfungen zwischen Taster und Leuchte
2. es gibt KEINE Direktverknüpfungen zwischen Bewegungsmelder und Leuchte
3. wenn der BM Bewegung erkennt soll die Leuchte x Zeit angehen.
4. wenn einer der Taster gedrückt wird, soll Leuchte angehen und an bleiben bis wieder ein Taster gedrückt wird.
So richtig?
Grüße
-
Genau so ist es. Laut Log wird bei Bewegung getriggert und nach 15s nochmal. Wollen zu ich das nicht, aber es ist so.
Ich nehme nur der Einfachheit halber einen Taster zum ein und einen zum Ausschalten. 1. hab ich zwei Taster dran und
2. muss ich ja sonst wieder abfragen ob das Licht an ist oder nicht
-
Ich hab da mal vorbereitet…
Allerdings nicht getestet.
!
<block xmlns="http://www.w3.org/1999/xhtml" type="procedures_defnoreturn" id="-Ts^et}f~sjE_@F_b@Zr" x="-287.6651715072096" y="462.5000152587891"><mutation><arg name="x"></arg></mutation> <field name="NAME">LeuchteSchalten</field> <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment> <statement name="STACK"><block type="comment" id="*6FI2{TA*|L*sW+,L(}?"><field name="COMMENT">Funktion Leuchte ein- oder ausschalten</field> <next><block type="controls_if" id="9?aGD0/BVm_Gr=?2ms+r"><value name="IF0"><block type="logic_compare" id="Yv]yu9}8NM]KwDy7Dkc5"><field name="OP">NEQ</field> <value name="A"><block type="get_value" id="7DWzNGXN52r-5ejij|N%"><field name="ATTR">val</field> <field name="OID">ID auswählen</field></block></value> <value name="B"><block type="variables_get" id="WOJ,=X],[ZWF1cE5o.B#"><field name="VAR">x</field></block></value></block></value> <statement name="DO0"><block type="control" id="*B4#g]93@QAUExJcA+k4"><mutation delay_input="false"></mutation> <field name="OID">Object ID</field> <field name="WITH_DELAY">FALSE</field> <value name="VALUE"><block type="variables_get" id="L}Bsm|]1G@6~G)e^!?(i"><field name="VAR">x</field></block></value></block></statement></block></next></block></statement></block> !
Grüße
-
Upps
Mir ist noch ein kleiner Schönheitsfehler aufgefallen.
Wenn man im Bad hin und her läuft, kann es sein das der BM mehrmals Bewegung meldet.
In meinem Beispiel würde dann jedesmal ein neuer Timer von 3 Min. gestartet.
Kriegst Du das alleine hin?
Grüße
-
Denke schon. Ich guck mir das an wenn ich wieder zu Hause bin. Danke dir erstmal [emoji4]
Sind die Blöcke normal untereinander eingehängt oder können die auch solo stehen?
-
@Alcalzone: Ich hatte auch den Verdacht, das die Variable vom Taster vielleicht auf true steht, deswegen am Anfang des Scriptes das Setzen aller Variablen auf false. Aber auch nach dem Neustart des Scriptes hat sich das Verhalten nicht geändert. `
Die Variable hast du selbst definiert und existiert nur innerhalb des Skripts. Ich meinte den tatsächlichen Datenpunkt "Taster oben….PRESS_SHORT", den du im BlockFalls Objekt "Bewegungsmelder Bad.MOTION"
abfragst. Der wird von Skript-Neustarts nicht beeinflusst, da es keine Skript-Variable ist, sondern ein Datenpunkt.
-
Ich meinte es mit der Variablen so, dass sie, aus welchen Gründen auch immer, vielleicht in einem undefinierten Zustand ist und habe deswegen am Anfang des Scriptes alles erstmal definiert auf 0 gesetzt. War nur so ein Gedanke. Ich kenne sowas aus meinem Job mit Alarm oder Brandmeldeanlagen. Wenn die in kurzer Zeit zu oft stromlos gemacht werden, können Ausgänge einen undefinierten Zustand annehmen, der weder 0 noch richtig 1 ist, und reagieren dann auch bis Neustart überhaupt nicht.
-
Also Rantanplan, was Du da mal vorbereitet hast…läuft.
Super, danke dafür. Jetzt muss ich´s nur noch verstehen, sonst weiß ich beim nächsten Mal wieder nicht weiter.
Den timeout stop habe ich eingefügt, somit ist Dein "Schönheitsfehler" weg. Wenn ich das richtig verstanden habe, läuft sonst bei jeder Bewegung ein Timer los und das Licht bleibt dann, gefühlt, ewig an.
Ich zerpflück jetzt mal alles um zu verstehen, was da abgeht.
Ich danke Euch Jungs, es wird nicht das letzte Mal sein, das wir uns "sehen"
-
Ich danke Euch Jungs, es wird nicht das letzte Mal sein, das wir uns "sehen"
`
Immer wieder gerne :!:Danke für die Rückmeldung.
(Meinen kleinen Fehler hätte ich mit einer weiteren Hilfvariablen gelöst
)
Grüße
-
Ich meinte es mit der Variablen so, dass sie, aus welchen Gründen auch immer, vielleicht in einem undefinierten Zustand ist und habe deswegen am Anfang des Scriptes alles erstmal definiert auf 0 gesetzt. War nur so ein Gedanke. `
In JavaScript (im Hintergrund von Blockly) sind Variablen zum Start tatsächlich undefined. Die sind dann aber nicht mal 0, mal 1, sondern haben einfach keinen Wert, bis man ihnen einen zuweist.Der "reset" am Anfang ist daher in einigen Fällen sogar angebracht.
-
@rantanplan: ich merk schon, das Du auf die Dinger stehst
@Alcalzone: dann war mein Gedanke ja garnicht so verkehrt, geschadet hat´s auf alle Fälle nicht
-
Hallo,
ich hoffe ich stelle mich nicht ins Abseits damit, aber es gibt auch eine Alternative direkt über die CCU2 ohne jegliches Script und Programm:
Ich habe einen Funkschalter-Bewegungsmelder HM-Sen-MDIR-WM55 sowie einen 2-fach Funkschalteraktor Unterputz HM-LC-Sw2-FM
Damit habe ich per Direktverknüpfung (DV) per Tastendruck Short –> Lampe 1 sowie Tastendruck LONG --> Lampe 2 geschaltet.
Nun noch eine DV angelegt die Lampe 1 per Bewegung einschaltet und die Art der Verweildauer von absolut auf mindestens ändern - Dauer kann individuell gewählt werden.
Licht ein per Taster = Dauerlicht
Licht ein per Bewegungserkennung = Dauer aktiv
So wollte ich es haben und funktioniert auch. Wie gesagt ist einfach nur ein Alternative mehr wollte ich nicht sagen. Wer es über das Blockly macht geht genauso gut
-
Du stellst Dich keineswegs ins Abseits. Ich hatte es am Anfang genauso. Es kommt zwar in der Fragestellung nicht raus, aber ich wollte zu unterschiedlichen Zeiten unterschiedliche Verzögerungen (in der Nacht zum Pinkeln kürzer als morgens zum Zähneputzen) und das geht mit der Methode nicht.
-
Du stellst Dich keineswegs ins Abseits. Ich hatte es am Anfang genauso. Es kommt zwar in der Fragestellung nicht raus, aber ich wollte zu unterschiedlichen Zeiten unterschiedliche Verzögerungen (in der Nacht zum Pinkeln kürzer als morgens zum Zähneputzen) und das geht mit der Methode nicht. `
Jo das stimmt! Damit ginge es nicht
So hat jeder seine individuelle Lösung
Gesendet von iPhone mit Tapatalk