NEWS
VIS-Widget-Wunsch: Countdown
-
Der Befehl für Windows war irgendwie anders, aber ich finde den Post nicht mehr.
Ich glaube ich werde morgen mal den Visa-Adapter löschen nachdem ich eine komplettsicherung gemacht habe.
EDIT:
Geschafft. Unter Windows ist das in einer Admin Dos Box im ioBroker Verzeichnis der Befehl:
iobroker upgrade iobroker.vis
Dann dauerts einen Moment und dann kommt ganz viel Data…
Und jetzt hab ich 5 hqWidgets ... Yes, ich liebe es wenn etwas funktioniert...
378_thermostatsteuerung.js -
Der Befehl für Windows war irgendwie anders, aber ich finde den Post nicht mehr.
Ich glaube ich werde morgen mal den Visa-Adapter löschen nachdem ich eine komplettsicherung gemacht habe. `
Du gehst mit der Konsole, da wo iobroker liegt. (Ich denke, die Konsole muss admin-Rechte haben)cd C:\Program Files\ioBroker iobroker upgrade iobroker.vis
-
Danke Bluefox.
Siehe mein Edit im letzten Post.
Ich hab einfach probiert und irgendwann hatte ich es dann.
Trotzdem Danke.
Hast Du schon eine "Roadmap" für weitere hqWidgets?
Aber nicht falsch verstehen… ich bin sehr geduldig.
-
Momentan bin ich an Rolladen:
Danach will ich Tür und Schloss machen. Dann weiß ich nicht. -
Hall Bluefox,
@Bluefox:Momentan bin ich an Rolladen: `
hui, das freut mich. Zwar offtopic: Wie schon mal beschrieben, wünsche ich mir, das Level auch umkehren zu können (Level 100% bedeutet Rollladen zu [bei Homepilot], statt auf [bei Homematic)].Gruß,
Pix
-
Hallo,
was macht die Zeile
> var timer = getState('countdown').val || 10;
??
bei mir zählt leider der Countdown fast doppelt zu schnell ??
Ich habe den Countdown über eine Variabel im trigger ON drin.
Funktioniert soweit auch alles, aber eben nur fast doppelt so schnell ?
// Idee von: http://forum.iobroker.net/viewtopic.php?t=737 // 05.05.2016 var logging = true; var szpfad = 'javascript.0.CountDown.'; // Variablen erstellen (Javascript Instanz nach dem ersten Speichern des Skriptes einmal neustarten) function create(szZaehler) { if (logging) log('Countdown-> function create Name: '+szZaehler,'info'); createState(szpfad+szZaehler , 300, {name: szZaehler ,desc: 'Countdownzähler',unit: 's'}); createState(szpfad+szZaehler+'_abgelaufen', false, {name: szZaehler+'_abgelaufen',desc: 'Countdown abgelaufen'}); createState(szpfad+szZaehler+'_trigger' , false, {name: szZaehler+'_trigger' ,desc: 'Trigger'}); createState(szpfad+szZaehler+'_max' , 300, {name: szZaehler+'_max' ,desc: 'Startwert'}); } // Zählen function count(szZaehler) { setTimeout(function () { //if (logging) log('CountDown-> function count: '+szZaehler,'info'); var timer = getState(szZaehler).val ;//|| 300; //if (logging) log('CountDown->count()->var timer: '+timer,'info'); if (timer > 1) { setState(szZaehler+'_trigger', false); setState(szZaehler, timer - 1); count(szZaehler); } else { setState(szZaehler, 0); setState(szZaehler+'_abgelaufen', true); } }, 1000); } // Countown ausführen function start(myobj,szCountDownObjekt){ // den Namen des Hauptobjektes bilden var szName = szpfad+szCountDownObjekt; // nun den Max wert laden if (logging) log('Countdown->function start->szName: '+szName,'info'); var iMax = getState(szName+'_max').val; if (logging) log('CountDown: iMax: '+iMax, 'info'); if (myobj.newState.val === true || myobj.newState.val === 'true' || myobj.newState.val == 1) { if (logging) log('Countdown->function start->Countdown start: '+myobj.name + "->" + szCountDownObjekt,'info'); setState(szName, iMax); setState(szName+'_abgelaufen', false); setState(szName+'_trigger', true); count(szName); } else{ if (logging) log('Countdown->function start->Countdown abgelaufen: '+myobj.name + "->" + szCountDownObjekt,'info'); setState(szName+'_trigger', false); setState(szName, 0); setState(szName+'_abgelaufen', true); } } // ON Trigger //on({id:"hm-rega.0.16281", change:"ne"}, function(obj) { xaktion(obj, "(i) Alarmüberwachung Zone 1","-> einschalten","-> ausschalten"); }); // varAlarm1CmdEin on({id:"hm-rega.0.16282", change:"ne"}, function(obj) { if (logging) log('Countdown->ON erkannt: '+'hm-rega.0.16281','info'); start(obj,'Z01_Alarm_Zone1'); }); // beim Start die Zähler anlegen if (logging) log('Countdown->Variablen anlegen','info'); create('Z01_Alarm_Zone1');
-
@pix:Hall Bluefox,
@Bluefox:Momentan bin ich an Rolladen: `
hui, das freut mich. Zwar offtopic: Wie schon mal beschrieben, wünsche ich mir, das Level auch umkehren zu können (Level 100% bedeutet Rollladen zu [bei Homepilot], statt auf [bei Homematic)].Gruß,
Pix `
Ist schon ewig da.
48_2016-06-13_17_38_49-edit_vis.png -
Ist schon ewig da. `
Oh, das hab ich übersehen. Vielen Dank. Beim Metro Widget für Jalousien gibt es den "invertieren"-Knopf aber nicht, oder?Gruß
Pix
-
Hätte hierzu mal eine ergänzende Frage.
Kann ich einen CUxD-Timer in ein Widget einbinden, um dessen Countdown anzuzeigen?
Der CUxD-Timer kennt ja nur die folgenden Parameter:
CMD_RET
INHIBIT
STATE
TIMER_EVENT
TIMER_GET
TIMER_SET
TIMER_STOP
WORKING
Sobald WORKING den Wert true hat, wird ausgehend vom Wert TIMER_SET heruntergezählt. Wenn 0s erreicht sind, geht WORKING auf false.
Ich suche jetzt nach einer Möglichkeit zur Anzeige des Countdowns als simplen Zahlenwert in einem Widget.
Gruß,
Thorsten
-
Lieber Thorsten,
der Lieblingsspruch im anderen Forum wäre jetzt:
Suche defekt? :lol:
Sieh mal da:
http://forum.iobroker.net/viewtopic.php … =Countdown
68 Treffer
Gruß
Rainer
-
Um es abzukürzen:
Geht nicht. Habe ich schon unter CCU.IO versucht, geht auch in ioBroker nicht. Die Javascript Lösung ist zuverlässig.
Gruß
Pix
-
Hi Pix,
also hiermit kann ich zumindest die Werte vom CUxD-Timer in einem Widget anzeigen lassen:
createState('AlarmCountdown'); function countdown() { var count = getState('hm-rpc.1.CUX2800001.2.TIMER_SET').val; var counter = setInterval(timer, 1000); function timer() { count=count-1; if (count <= 0) { clearInterval(counter); return; } setState('AlarmCountdown', count); } } on({id: "hm-rpc.1.CUX2800001.2.WORKING", change: "true"}, function () { countdown(); });
Aktuell ist mein Problem jedoch, wie ich den Timer gestoppt bekomme, wenn zwischenzeitlich WORKING auf "false" springt. Wenn ic eine zusätzliche Abfrage in "if (count <= 0)" einfüge, fängt der Countdown an zu stottern. Hast Du eine Idee?
Gruß,
Thorsten
-
Das ist aber irgendwie ein Mix aus CUxD und Javascript, oder? mit SetInterval zählst du doch in Javascript sekündlich. Das macht doch nicht der CUxD. Von dem nimmst du nur den eingestellten Wert.
Bei mir wurde nie der TIMER_GET-Wert aktualisisert. Der stand immer auf dem Startwert und nach Ablauf auf 0. Zwar wurde die Aktion nach Ablauf ausgeführt (TIMER_EVENT = true), aber der Countdown nicht angezeigt.
Es entspricht auch nicht meiner Philosophie, die Logik auf ioBroker in Javascript laufen zu lassen und dann einen Countdown über ein Addon auf einem angeschlossenen Satellitensystem laufen zu lassen
Gruß
Pix
PS: Timer stoppen mit TIMER_STOP true
-
Hallo pix,
Bluefox hatte doch mal ein Countdown Widget, bestehend aus einem JavaScript Teil und einem ???-widget.
Ich finde es im Moment leider nicht.
War hier im Forum mit animiertem gif vorgestellt.
Gruß
Rainer
-
Hallo Rainer,
4. Post in diesem Thread
Pix
Gesendet mit Tapatalk
-
Guten Abend,
ich würde gerne einen Sleeptimer mit Countdown erstellen (siehe http://forum.iobroker.net/viewtopic.php … =countdown).
Bezogen auf den 4. Post in diesem Thread frage ich mich, wo ich das Java-Skript einfügen/speichern/ablegen soll. ich bin da leider absoluter Neuling…
Zudem möchte ich, dass der Timer Minuten und Sekunden anzeigt und bei einem erneuten Klick auf den Button neu startet.
Ich würde mich sehr freuen, wenn mir da jemand weiterhelfen kann!
-
@pix:Hallo Rainer,
4. Post in diesem Thread `
Und ich suche überall nur nicht hier :shock: :oops: :lol:Danke
Rainer
-
@pix:Das ist aber irgendwie ein Mix aus CUxD und Javascript, oder? mit SetInterval zählst du doch in Javascript sekündlich. Das macht doch nicht der CUxD. Von dem nimmst du nur den eingestellten Wert. `
Korrekt. Es geht mir einzig um die Visualisierung des CUxD-Timers in vis. Ich will damit in ioBroker absolut nichts steuern.
@pix:Bei mir wurde nie der TIMER_GET-Wert aktualisisert. Der stand immer auf dem Startwert und nach Ablauf auf 0. Zwar wurde die Aktion nach Ablauf ausgeführt (TIMER_EVENT = true), aber der Countdown nicht angezeigt. `
So ist es auch bei mir. Darum der Workaround über Javascript zur Anzeige des Countdowns. Wie gesagt, ich möchte auf den CUxD-Timer nicht verzichten. Ich will lediglich eine Visualisierung, die zeitgleich mit dem CUxD-Timer startet.
@pix:Es entspricht auch nicht meiner Philosophie, die Logik auf ioBroker in Javascript laufen zu lassen und dann einen Countdown über ein Addon auf einem angeschlossenen Satellitensystem laufen zu lassen `
Kann ich durchaus nachvollziehen. Aber ich möchte in diesem Fall ein System, das weiterhin autark auf der CCU2 läuft und nicht von einem angeschlossenen Satellitensystem (ioBroker) abhängt. Gleichzeitig möchte ich aber die Option haben, mir die Zeitspanne bis zum Scharfstellen der Anlage in vis anzeigen zu lassen.
@pix:PS: Timer stoppen mit TIMER_STOP true `
Nützt mir leider nichts, da ich das ja auch im Javascript abfragen müsste. Dann kann ich auch auf das Umschalten von WORKING auf false triggern. Mein Problem ist eher, wo und wie ich das im obigen Javascript am besten einbinde. Der Timer soll nach dem Wechsel von WORKING von true auf false einfach nur stoppen. Im Moment zählt er weiter. Ist allerdings auch nicht wirklich tragisch, weil ich das Widget nur bei WORKING = true anzeigen lasse und es bei WORKING = false ausblende.
-
@pix:Hallo,
ich wünsche mir ein Countdown-Widget. Praktisch eine Aus-/Einschaltverzögerung. Es soll auf Änderung eines Wertes (einer ObjID) reagieren und dann eine festgelegte Zeit herunterzählen (in Sekunden). Und bei 0 angekommen soll es mit State wieder einen Wert (in anderer ObjID) setzen. Verknüpfungen mit einem CUxD-Timer klappten nicht so recht. Ich habe auch schon ein paar Versuche hinter mir, das im JavaScript Adapter zu basteln. Leider bekomme ich es mit Interval() oder SetTimeout() nicht hin. Die CPU-Last wird viel zu hoch, selbst mein MacMini geht in die Knie.
Ist das möglich?
Gruß
Pix `
Javascript:
createState('countdown', 10); createState('afterCount', false); createState('countTrigger', false); function count() { setTimeout(function () { var timer = getState('countdown').val || 10; if (timer > 1) { setState('countTrigger', false); setState('countdown', timer - 1); count(); } else { setState('countdown', 0); setState('afterCount', true); } }, 1000); } on('countTrigger', function (obj) { if (obj.newState.val === true || obj.newState.val === 'true' || obj.newState.val == 1) { setState('countdown', 10); setState('afterCount', false); count(); } });
Widgets:
!
[ { "tpl": "tplHqButton", "data": { "visibility-cond": "==", "visibility-val": 1, "oid": "javascript.0.countTrigger", "min": "false", "max": "true", "iconName": "img/bulb_off.png", "btIconWidth": "56", "offsetAuto": "true", "leftOffset": "15", "topOffset": "55", "timeAsInterval": "true", "infoLeftFontSize": "12", "infoFontRightSize": "12" }, "style": { "left": "64px", "top": "61px" }, "widgetSet": "hqWidgets" }, { "tpl": "tplHqCircle", "data": { "visibility-cond": "==", "visibility-val": 1, "oid": "javascript.0.countdown", "min": "0", "max": "10", "step": "1", "displayPrevious": "true", "readOnly": true, "unit": "s" }, "style": { "left": "174px", "top": "58px" }, "widgetSet": "hqWidgets" }, { "tpl": "tplHqButton", "data": { "visibility-cond": "==", "visibility-val": 1, "oid": "javascript.0.afterCount", "min": "false", "max": "true", "iconName": "img/bulb_off.png", "btIconWidth": "56", "offsetAuto": "true", "leftOffset": "15", "topOffset": "55", "timeAsInterval": "true", "infoLeftFontSize": "12", "infoFontRightSize": "12" }, "style": { "left": "274px", "top": "61px" }, "widgetSet": "hqWidgets" } ]
`wie genau nutze ich hier das Javascript? Ich möchte gerne die Obj.ID (hm-rpc.0.MEQ03XXXX0.1) einfügen und damit den Counter starten. Aber ich weiß leider nicht, an welche Stelle ich die ID eintragen muss.
-
Ich schiebe dies nochmal nach oben.
Habe mich versucht etwas einzulesen und einfach Javascripte zu begreifen, hier bekomme ich es leider nicht hin.