NEWS
[gelöst]Dimmen mit "Long Press"
-
@R1Snake sagte:
Hier den Pfad von release_hold
Ich würde vermuten, dass "release_hold" erst beim Loslassen true wird ?
Wie verhalten sich die Datenpunkte "hold" und "release_hold" (loggen) ? -
@paul53 das Script kann man doch auch bestimmt umbauen für Homatic Dimmer, die haben keinen .on Datenpunkt. Gibt nur den .level Datenpunkt.
-
@coyote sagte:
Homatic Dimmer, die haben keinen .on Datenpunkt.
Haben HM-Dimmer nicht einen .STATE Datenpunkt ? Dieser würde dem .on Datenpunkt entsprechen.
-
@paul53 nein leider nicht.
-
@coyote sagte:
nein leider nicht.
Also sind die HM-Dimmer immer an und werden nur durch den LEVEL gesteuert ? Dann lasse alles mit Bezug auf idSwitch und der Variablen state weg.
-
@paul53 genau, werden nur über level gesteuert. Ok, werde ich testen. Danke dir.
-
@paul53 unklar ist mir, was mit dem letzten Block ist, den brauche ich doch, damit ich überhaupt auf den LongPress reagiere, aber da ist state und switch drin. Den müsste man etwas umbauen oder?
const idLevel = "meinAdapter.0.CC78CB0000261884.bri"; // meinAdapter anpassen ! const idLong = "mihome.0.devices.switch_158d0001f3a5b2.long"; var level = getState(idLevel).val; var down = false; if(level > 90) down = true; var timer = null; function rampe() { if(down) { level = level - 5; if(level < 0) down = false; else setState(idLevel, level); } else { level = level + 5; if(level > 100) down = true; else setState(idLevel, level); } } on(idLong, function(dp) { if(dp.state.val) { if(!state) setState(idSwitch, true); timer = setInterval(rampe, 200); } else clearInterval(timer); });
Edit: Oder dann einfach die zweite if Zeile weg lassen?
-
@coyote sagte:
einfach die zweite if Zeile weg lassen?
Ja, Zeile 25 weglassen.
Sendet PRESS_LONG nicht alle 250 ms ? Dann kann man auch das Intervall weglassen und der Trigger muss anders aussehen.on({id: idLong}, rampe); // Triggert bei jeder Zeitstempeländerung
-
@paul53 hm, das weiß ich nicht. Kann ich aber ja ausprobieren.
-
@coyote sagte:
Kann ich aber ja ausprobieren.
Ja, mache es. Hast Du HM (classic) oder HmIP ? Bei HM classic sendet PRESS_CONT alle 250 ms.
-
@paul53 HM (Classic), dann sollte es ja passen.
-
@coyote sagte:
HM (Classic)
Dann muss PRESS_CONT verwendet werden.
const idLevel = "hm-rpc.xxx.LEVEL"; const idLong = "hm-rpc.xxx.PRESS_CONT";
-
@paul53 ah moment, nee das geht nicht. Den DP habe ich nicht, da ich über einen Taster auf ein 12/7 wired Modul gehe, da gibts nur Press_Long und Press_Short. Das steuert mir dann den wireless HM Dimmer
-
@coyote sagte:
ein 12/7 wired Modul gehe
Wie verhält sich PRESS_LONG ? Testen:
on({id: idLong}, function(dp) { log('Taste long: ' + dp.state.val; });
-
javascript.0 2020-05-28 16:17:39.719 info (18624) script.js.Skript_1: Taste long: true
-
@coyote
Nur ein Log-Eintrag ? Beim Loslassen ? -
@paul53 Log -Eintrag kommt immer beim Drücken, ich denke ich weiß worauf du hinaus willst, kann es aber momentan nur über die Web-Gui testen, da ich nicht vor Ort bin und da kann ich die "Taste" eben nicht einfach lang halten, dachte dass geht auch über die GUI. Muss es also direkt am Taster ausprobieren, wenn ich zu Hause bin.
-
@coyote sagte:
Muss es also direkt am Taster ausprobieren
Ja, das kann nur mit der physischen Taste getestet werden.
-
@paul53 also auch wenn ich den Taster lang drücke und dann halte, wird nur einmal "true" geloggt mehr nicht. Dann wird das so wohl nicht funktionieren
-
@coyote sagte:
wird nur einmal "true" geloggt
Logge mal gleichzeitig PRESS_SHORT beim langen Drücken der Taste
on({id: idLong}, function(dp) { log('Taste long: ' + dp.state.val; }); on({id: idShort}, function(dp) { log('Taste short: ' + dp.state.val; });