NEWS
Bilder alle x Sekunden wechseln
-
-
Hallo,
ich würde auch auf jeden Fall ein Skript nutzen. Man kann nun überlegen, was das Skript übernehmen soll und was das Widget.
Natürlich kann ein Skript alles übernehmen und den URL zum Bild alle paar Sekunden in einen Datenpunkt schreiben.Man kann aber auch per Skript einfach nur eine aufsteigende Zahl in einen Datenpunkt schreiben. Sagen wir 1 bis 10, Wechsel alle 1s. Dann könnten mehrere Widgets in VIS damit gesteuert werden. Ich nenne das Rolle.
/* Skript zählt ganze Zahlen hoch bis Maxwert, dann Reset auf Minwert */ const idNummer = "VIS.Webcam.Rotation.Nummer"; // Pfad zum Datenpunkt const delay = 1; // Verzögerung beim Hochzählen in Sekunden const min = 0; // minimaler Wert const max = 10 // maximaler Wert // ab hier nix mehr ändern createState(idNummer, min, { // Datenpunkt erstellen name: 'VIS Webcam (rotierend) Nummer', desc: 'aufsteigende Nummer', def: min, type: 'number' }); // Rolle let x = min; setInterval(function () { x = x + 1; // neue Version setState(idNummer, x); // neue Version // setState(idNummer, x+1); // Alte Version vor Korrektur durch OliverO if (x == max) x = min-1; }, delay * 1000);
Jetzt kannst du mit den "8er"-Widgets darauf reagieren.
Oder über die Sichtbarkeit nur bei Wert >= 5 etwas anzeigen lassen (5s an, 5s aus) oder über gerade/ungerade im Sekundentakt blinken.Gruß
Pix -
HI @pix!
Vorab, ganz lieben Dank. An so etwas habe ich über Blockly gedacht, aber noch nicht begonnen. Dein Script habe ich für meine Voraussetzungen angepaßt, aber es tut nicht. Ich sitze jetzt schon seit Stunden um den Fehler zu finden, steige aber nicht dahinter.Hier das abgewandelte Script:
Was passiert, oder eben auch nicht:
Ich starte das Script, nach Ablauf der ersten Verzögerung wird mein DP auf 1 geändert. Die verwendeten delayzeiten passen, das funktioniert. Nach Ablauf der nächsten Verzögerung blinkt der DP wieder auf und bleibt aber beharlich auf 1. Ist sicher ganz trivial, ich habe auch schon stundenlang hier herumgesucht und probiert, auch hier, komme aber nicht weiter. Ich habe das Gefühl, die function() startet bei jedem Durchlauf mit "let x = min", auch ein ändern auf "var" hilft nicht.@pix, wo muss ich was ändern?
LG, mxa
-
Hallo mxa,
der Ablauf bei Deinem Skript ist so:
- Skriptstart x wird mit min befüllt, also 0
- Intervall startet
- Datenpunkt wird sofort mit 0 + 1, also 1 beschrieben
- Prüfung, ob x schon max erreicht hat, wenn ja x wieder mit min (0) füllen
- 5 * 1000ms warten und Intervall wieder starten
Sollte gehen. Du hast meine Zeile 24 (deine Zeile 26) abgewandelt. Das minus 1 sorgt dafür, dass der Datenpunkt auch wirklich den Minimalwert bekommt, denn setState() schreibt ja sofort x+1
Ich sehe ein Problem in deinem State / Datenpunkt.
Es ist in meinen Augen nicht gut, Datenpunkte außerhalb des Javascript-Adapters (vermutlich von Hand) anzulegen. Du solltest dabei unbedingt auf den Typ und ggf. auf die Rolle achten. Läuft denn mein Skript bei dir, wenn du nur die Anpassungenconst delay = 5; // Verzögerung beim Hochzählen in Sekunden const min = 0; // minimaler Wert const max = 9; // maximaler Wert
vornimmst?
Gruß
Pix -
@metaxa
der fehler liegt daran, dass du zwar 1 zu x addierst,
das ergebnis aber nicht wieder in x abspeicherst.
deswegen bleibt x immer 0setInterval(function () { x = x + 1; setState(idNummer, x ); if (x == max) x = min; }, delay * 1000);
-
Eine Frage zu deinem ursprünglichen Anwendungsfall:
Sind die 6 Bilder immer fix oder ändern die sich immer wieder mal?
Ist das eine Abbildung deines Mähroboters, der auf dem Bildschirm rumfährt
aber halt nur symbolisch ohne irgendein realen Hintergrund?Dann könntest du auch mal noch unter CSS-Animationen schauen.
Wenn da keine dynamischen Daten beteiligt sind,
dann kannst du das rein im Browser laufen lassen
Hier ein Beispiel: https://codepen.io/mmzzba/pen/VpRbjz -
@OliverIO Du hast natürlich recht, werde das oben mal für Nachbauer korrigieren https://forum.iobroker.net/post/270338
Danke! Ist passiert, weil ich meinen (funktionierenden) Code nicht komplett kopiert habe, um ihn zu vereinfachen. Ein x++ ist rausgeflutscht.
-
@pix & @OliverIO!
Lieben Dank Euch beiden! Was mich jetzt nur so ärgert, ich sitze stundenlang und behirne es einfach nicht, finde den offensichtlichen Fehler nicht. Zeile eingefügt und schon läuft es astrein, nichmals großes Danke!Aus der Not ein Tugend gemacht, hatte ich mich dann im Frust in Blockly versucht:
Script 1:
Script 2:
Da habe ich mich ausgetobt, denn das hätte meine JS-Anfängerschritte völlig überfordert. Aber, jetzt werde ich eine Mischung machen, denn der Intervall im Blockly .... sieht sehr anfällig aus und ich habe Angst, dass der irgendwann mal hängen bleibt.
LG, mxa
-
@OliverIO sagte in Bilder alle x Sekunden wechseln:
Hier ein Beispiel: https://codepen.io/mmzzba/pen/VpRbjz
Ja, genau ...... da bin ich Kilometer weit enfernt. Genau soetwas wäre natürlich das Sahnehäubchen. Wenn ich das dann schaffe, wohin mit der CSS, wie aufrufen, wie und wo ?????. Die Baustelle ist mir um mehrere Schuhgrößen zu groß
Wenn meine Dolly mal über meine Tablets tuckelt, dann mache ich mir um meinen künftigen Job und mein Einkommen keine Sorgen mehr.
Ich bleibe mal bei meinem Leisten, die kann ich gegebenenfalls dann auch selbst anpassen.
LG, mxa
-
@metaxa schau dir mal das beispiel mit dem codepen link an,
da kannst du auch direkt drin spielen
bei self.html ist jeder einzelne befehl erklärt und direkt mit beispielen hinterlegt
css wird nicht aufgerufen, sondern ist im Browser einfach da.
Damit wird mittlerweile eine komplette Webseite formatiert und wurde
in den Jahren mit immer mehr Funktionen gefüllt.