NEWS
Restlaufzeitanzeige - Umsetzungsidee gesucht
-
Bei meiner Beleuchtung werden alle Lampen bei nicht vorhandener Bewegung im Raum nach einer festgelegten Zeit automatisch ausgeschaltet. In meiner VIS möchte ich die verbleibede Zeit bis zum automatischen Ausschalten am liebsten sekundengenau angezeigt bekommen.
Bisher habe ich das in einem Skript gemacht das jede Sekunde die Restlaufzeit für eingeschaltete Lampen berechnet, diese in einen String "Stunden:Minuten:Sekunde" umwandelt und in einen Datepunkt der Lampe schreibt der dann in der Vis angezeigt wird.
Seit Javascript 6.1.0 ist ja als Vorgabe eingestellt, dass ein Skript, dass mehr als 1000 Datenpunkte pro Minute schreibt, automatisch gestoppt wird. Bei mehr als 16 engeschalteten Lampen wird dieser Wert erreicht. Jetzt kann ich natürlich diesen Wert einfach hochsetzen, aber ich würde lieber eine elegante Lösung für eine sekundengenaue Restlaufanzeige umsetzen.
Eine Idee wäre z.B. das ganze über Bindings in VIS zu machen. (Abfrage ob Lampe an, wenn ja, aktuelle Zeit minus Timestamp .lc der Lampe minus maximale Brenndauer), ob das unbedingt resourcenschonender ist weiß ich nicht.
Hat jemand eine andere Idee? -
@wolfgangfb
Schaltest Du die Lampen alle separat?
Oder hast Du einen Timer, der bei Ablauf alle (max. 16) Lampen ausschaltet?
Dann würde ja 1 DP (in 0_userdata) ausreichen. -
@codierknecht
Die Lampen werden separat geschaltet. Die im Flur geht. z.B. nach 5 Minuten aus, im Wohnzimmer erst nach 3 Stunden (damit man auch in Ruhe ein Buch lesen kann ohne im Dunkeln zu sitzen). -
@wolfgangfb sagte: im Wohnzimmer erst nach 3 Stunden
Weshalb muss die Restzeitanzeige dann sekundengenau sein?
-
Suche benutzt ?
z.B. nach countdownGibt hier zahlreiche Scripte.
z.B.
https://forum.iobroker.net/topic/60403/countdown-von-10-min-auf-0-runter/9?page=1 -
@paul53 sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
@wolfgangfb sagte: im Wohnzimmer erst nach 3 Stunden
Weshalb muss die Restzeitanzeige dann sekundengenau sein?
Weil die Logik für alle Lampen gleich ist und die Zeit beliebig eingestellt werden kann.
Und selbst wenn ich die Restlaufzeit nur die letzte Minute sekundengenau anzeigen lassen würde könnte es sein, dass mehr als 16 Lampen in dieser Minute unter 60 Sekuden sind und das Skript dann wegen >1000 Schreibvorgängen beendet werden würde. -
@bahnuhr sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
Suche benutzt ?
Ja
z.B. nach countdown
Gibt hier zahlreiche Scripte.
z.B.
https://forum.iobroker.net/topic/60403/countdown-von-10-min-auf-0-runter/9?page=1Ich suche kein Countdown Skript, ich weiß wie ein Countdown Skript geht. Die Skripte, die dort zu finden sind, schreiben auch alle jede Sekunde in einen Datenpunkt und ich suche eine Lösung, wie man das optimieren kann wenn man eben mehr als einen Countdown hat.
-
@wolfgangfb sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
wenn man eben mehr als einen Countdown hat.
Ich dachte du suchst, wie man einen Countdown in VIS anzeigt.
Aber das schein ich dann ja falsch verstanden zu haben.
Ansonsten hast du die Lösung von mir oben genannt bekommen.
-
@wolfgangfb sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
ich suche eine Lösung, wie man das optimieren kann wenn man eben mehr als einen Countdown hat
Statt 16 DP könnte man einen nehmen und die Timer als Array oder JSON verwalten.
Das eigentliche Problem behebt das allerdings nicht.Das ist aber eher ein hypothetisches Problem. Oder hast Du tatsächlich 16 Timer gleichzeitig laufen?
Zur Not könnte man im Adapter auch das Limit auf 1.000 einfach erhöhen. Holzhammermethode
-
@codierknecht sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
@wolfgangfb sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
ich suche eine Lösung, wie man das optimieren kann wenn man eben mehr als einen Countdown hat
Statt 16 DP könnte man einen nehmen und die Timer als Array oder JSON verwalten.
Das eigentliche Problem behebt das allerdings nicht.Doch, an die Lösung mit Array oder Json habe ich auch schon gedacht, ich weiß dann nur nicht wie ich in VIS aus einem Json oder einem Array genau einen Wert anzeige, wenn Du mir dazu einen Lösungsansatz nennen könntest wäre mir geholfen.
Das ist aber eher ein hypothetisches Problem. Oder hast Du tatsächlich 16 Timer gleichzeitig laufen?
Ich habe mehr als 16 Lampen Ich habe natürlich nich für jede Lampe ein eigenes Skript.
Ich habe genau ein Skript, dass einmal jede Sekunde ausgeführt wird. Das geht über eine Schleife alle Lampen durch,const LichtStateDP = $('alias.0.Raum.*.Licht.*.state'); ... schedule("*/1 * * * * *", function () { var AktuelleZeit = (new Date().getTime()); for(var i=0; i<LichtStateDP.length; i++){ var LichtState = getState(LichtStateDP[i]).val; // ist das Licht eingeschaltet if (LichtState == true){ // Zeeiten überprüfen, Licht ausschalten etc.
wenn die Lampe eingeschaltet ist schaut es nach, wie lange die ohne zugeordnete Bewegung an sein darf, berechnet die Zeit wie lange die Lampe schon an ist, ist die Zeit kleiner als die erlaubte Zeit wird in den Restlaufzeit Datenpunkt die verbleibende Zeit geschrieben (die dann in VIS für die entsprechende Lampe angezeigt wird), dieser Schreibvorgang ist der kritische Punkt! Ist die Zeit größer als die erlaubte Zeit, wird die Lampe ausgeschaaltet.
Zur Not könnte man im Adapter auch das Limit auf 1.000 einfach erhöhen. Holzhammermethode
Das will ich ja gerade vermeiden.
Ist eigentlich nur das Schreiben von Datenpunkten so schlimm oder sollte man auch das Lesen reduzieren (in meinem Fall auf die Lichtereignisse zusätzlich triggern und die Zustände in einem Array halten)?
-
da könnte ich diesen adapter von mir empfehlen
https://github.com/oweitman/ioBroker.mytimedarin gibt es den countdown timer mit entsprechenden anzeige widgets.
das sekündliche abfragen macht eigentlich kein sinn, wenn dann würde ich nur was machen wenn tatsächlich auch was passiert (licht ein: timer starten, licht aus: timer stoppen/resetten, timer abgelaufen: licht aus)
-
@wolfgangfb sagte: sollte man auch das Lesen reduzieren (in meinem Fall auf die Lichtereignisse zusätzlich triggern und die Zustände in einem Array halten)?
Es reduziert auch die Systemlast, obwohl Lesen (aus dem JS-Instanz-Puffer) weit weniger komplex ist als Schreiben.
-
@oliverio sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
da könnte ich diesen adapter von mir empfehlen
https://github.com/oweitman/ioBroker.mytimedarin gibt es den countdown timer mit entsprechenden anzeige widgets.
Die Installation klappt bei mir nicht. Ich uss den ja aus github installieren.
Es kommt:$ iobroker url https://github.com/oweitman/iobroker.mytime --host raspberrypi --debug install oweitman/iobroker.mytime#d3d71b42d0320f577230e10452f2855ad0a8cd48 NPM version: 8.15.0Installing oweitman/iobroker.mytime#d3d71b42d0320f577230e10452f2855ad0a8cd48... (System call)
und dann passiert (seit 10 Minuten) nichts.
Aber mal rein vom Verständnis. Wenn ich das richtig verstehe setzt der ja auch jede Menge Datenpuinkte. Ist das aus einem Adapter weniger schlimm als aus einem Javascript? -
@wolfgangfb
Nein du solltest ihn von Stable
Installieren
Aktuell bin ich in Vorbereitung einer neuen Version die mit der aktuellen Admin besser arbeitet. Auf Guthaben ist der aktuelle nicht langfädige EntwicklungsstandJe nach Browser kann es aktuell etwas schwierig sein ein neuen Countdown Timer einzurichten
-
@oliverio sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
Auf Guthaben ist der aktuelle nicht langfädige Entwicklungsstand
Hat hier die Textersetzung zugeschlagen? Ich versteh' nur Bahnhof
-
@codierknecht
Ja
Guthaben = Github
Und
Lauffähig -
@oliverio sagte in Restlaufzeitanzeige - Umsetzungsidee gesucht:
Nein du solltest ihn von Stable Installieren
Servus! Ich bin auf Stable
dein Adapter wird mir aber leider nicht angeboten?
Im Repro Latest wird mir die v 0.7.12 angeboten
Soll ich besser warten bis
Aktuell bin ich in Vorbereitung einer neuen Version die mit der aktuellen Admin besser arbeitet.
Danke für deine Arbeit!
LG, mxa -
hm,
der adapter muss automatisch deinstalliert worden sein.
selbst auf meiner entwicklungsmaschine ist er nicht mehr
leider fin ich auf github da kein commit in den repositories
wo das entfernt worden ist -
@oliverio Danke für deine Rückmeldung. Ich warte mal ab, bis sich da oder dort was tut. Du für dein dankenswertes Hobby Zeit hast.
LG