Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Script zum umschalten der Werte

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Script zum umschalten der Werte

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 last edited by

      Die Objekte sehen klar nach State-Objekten aus und die IDs stimmen offenbar auch.

      Sind bei allen 3 Objekten Werte im Reiter "Objekte" oder "Zustände" zu sehen ?

      1 Reply Last reply Reply Quote 0
      • M
        Marcolotti last edited by

        Ja, die Werte sind da. Jedoch wenn die PV-Anlage nichts ins Netz speist, dann ist der Wert auf 0. Logisch. 😉 Beim Wert null kommt der Fehler. Das müsste man abfangen.

        1 Reply Last reply Reply Quote 0
        • paul53
          paul53 last edited by

          null und 0 ist nicht das Gleiche. Der Wert 0 dürfte keine Probleme machen. Nur wie kommt dort null hinein ? Das sollte verhindert werden.

          1 Reply Last reply Reply Quote 0
          • paul53
            paul53 last edited by

            Anmerkung zu Deinem Zähler:

            setState("javascript.0.Displayzaehler", getState("javascript.0.Displayzaehler").val + 1);
            

            sorgt dafür, dass "Displayzaeher" erst einmal auf 3 springt, bevor er kurz danach auf 0 zurück gesetzt wird. Besser:

            schedule("*/1 * * * *",  function () { // jede Minute
            var cnt = getState("javascript.0.Displayzaehler").val + 1;
            if (cnt > 2) cnt = 0;
            setState("javascript.0.Displayzaehler", cnt);
            
            if (cnt === 0) setState("javascript.0.Displayanzeige", "Netzbezug");
            
            else if (cnt  == 1) setState("javascript.0.Displayanzeige", "PVLeistung");
            
            else setState("javascript.0.Displayanzeige", "Einspeisung");   
            
            }); // end of schedule
            
            1 Reply Last reply Reply Quote 0
            • P
              pix last edited by

              Hallo,

              auch wenn ich hier jetzt komplett Verwirrung stifte :lol:

              Jetzt habe ich auch kapiert, dass es sich um eine Anzeige handelt, die jede Minute entweder den Bezug, die PVLeistung oder die Einspeisung abwechselnd darstellt. Und das jeweils für eine Minute.

              Wenn nicht noch an anderer Stelle (zB mit VIS Widget State val) die Displayanzeige geändert werden soll, dann würde ich die "rollenartige" Anzeige anders angehen. Nämlich mit einem Interval. Ich lasse so in einem Widget verschiedene Webcams und Grafiken alle zehn Sekunden alternierend anzeigen:

              ! var idBezug = 'modbus.0.inputRegisters.30865_Bezug'; var idPVLeistung = 'modbus.0.inputRegisters.30775_PVLeistung'; var idEinspeisung = 'modbus.0.inputRegisters.30867_Einspeisung'; ! var idZaehler = 'javascript.0.Displayzaehler', idAnzeige = 'javascript.0.Displayanzeige', idInhalt = 'javascript.0.Displayinhalt'; ! var x = 0; // Zähler ! setInterval(function () { if (x === 0) { setState(idAnzeige, 'Netzbezug'); setState(idInhalt, getState(idBezug).val); } else if (x==1) { setState(idAnzeige, 'PVLeistung'); setState(idInhalt, getState(idPVLeistung).val); } else if (x==2) { setState(idAnzeige, 'Einspeisung'); setState(idInhalt, getState(idEinspeisung).val); } log('Displayinhalt: ' + getState(idInhalt).val); x++; // hochzählen if (x == 3) x = 0; // Reset }, 60 * 1000); // jede Minute ! // Modbus inputRegisters überwachen on( { id: /\.inputRegisters.*$/ }, function(obj) { if (!obj.state.val) { // wenn kein Wert da // Welcher der drei Werte ist hier gemeint? var nameDatenpunkt = (obj.id).split('_'); // zB javascript.0.Alarm.Schlafzimmer.Luftfeuchte.Grenzwert nameDatenpunkt = nameDatenpunkt[nameDatenpunkt.length]; // letzter Teil nach dem Unterstrich (also Bezug,PVLeistung oder Einspeisung) var nameVariable = 'id' + nameDatenpunkt; setState(nameVariable, 0); // Wert auf '0' statt 'null' } }); !
              Unten ist noch eine Funktion eingebaut, die die drei Modbus-Datenpunkt überwacht. Man kann natürlich für jeden dieser drei Datenpunkte eine eigene Funktion schreiben````
              on( idBezug, function(obj) {
              if (!obj.state.val) setState(idBezug, 0); // Wert auf '0' statt 'null'
              });
              on( idPVLeistung, function(obj) {
              if (!obj.state.val) setState(idPVLeistung, 0);
              });
              on( idEinspeisung, function(obj) {
              if (!obj.state.val) setState(idEinspeisung, 0);
              });

              
              Achtung: __idPV__ muste in __idPVLeistung__ (analog zur Modbus-Datenpunkt-Bennung umbenannt werden).
              
              Probier das mal (hab es noch nicht getestet).
              
              Gruß
              
              Pix
              1 Reply Last reply Reply Quote 0
              • Bluefox
                Bluefox last edited by

                Man muss 3 Werte anzeigen mit 3 Widgets und deren Visibility über setInterval steuern.

                Vorteil: auch wenn während das Wert angezeigt wird, das Wert sich ändert, das wird auch angezeigt.

                Bei deiner Lösung das Wert wird statisch sein und nur beim nächsten Anzeigen wird upgedated.

                1 Reply Last reply Reply Quote 0
                • P
                  pix last edited by

                  Hallo,
                  @Bluefox:

                  Man muss 3 Werte anzeigen mit 3 Widgets und deren Visibility über setInterval steuern.

                  Vorteil: auch wenn während das Wert angezeigt wird, das Wert sich ändert, das wird auch angezeigt.

                  Bei deiner Lösung das Wert wird statisch sein und nur beim nächsten Anzeigen wird upgedated. `
                  das ist völlig richtig. Danke für den Hinweis.

                  Also einfach den Interval laufen lassen und eine Variable für die Anzeige verwenden

                  ! var idBezug = 'modbus.0.inputRegisters.30865_Bezug'; var idPVLeistung = 'modbus.0.inputRegisters.30775_PVLeistung'; var idEinspeisung = 'modbus.0.inputRegisters.30867_Einspeisung'; ! var idZaehler = 'javascript.0.Displayzaehler'; var x = 0; // Zähler für Interval ! setInterval(function () { setState(idZaehler, x); log('Displayzaehler: ' + getState(idZaehler).val); x++; // hochzählen if (x == 3) x = 0; // Reset }, 60 * 1000); // jede Minute !
                  unten dran wieder entweder Regexp

                  // Modbus inputRegisters überwachen
                  on( {
                      id: /\.inputRegisters.*$/
                  }, function(obj) {
                      if (!obj.state.val) { // wenn kein Wert da
                          // Welcher der drei Werte ist hier gemeint?
                          var nameDatenpunkt = (obj.id).split('_'); // zB modbus.0.inputRegisters.30865_Bezug
                          nameDatenpunkt = nameDatenpunkt[nameDatenpunkt.length]; // letzter Teil nach dem Unterstrich (also Bezug,PVLeistung oder Einspeisung)
                          var nameVariable = 'id' + nameDatenpunkt;
                          setState(nameVariable, 0);    // Wert auf '0' statt 'null'
                      }
                  });
                  

                  oder einfach

                  on( idBezug, function(obj) {
                      if (!obj.state.val) setState(idBezug, 0);    // Wert auf '0' statt 'null'
                  });
                  on( idPVLeistung, function(obj) {
                      if (!obj.state.val) setState(idPVLeistung, 0);
                  });
                  on( idEinspeisung, function(obj) {
                      if (!obj.state.val) setState(idEinspeisung, 0);
                  });
                  >! ````Das funktioniert natürlich nur, wenn du aus Javascript die Datenpunkte des modbus-Adapters beschreiben kannst. Wenn nicht, brauchst du noch jeweils eine neue Variable in Javascript, die die modbus-Werte (ggf. korrigiert) einliest und die du später in VIS verwenden kannst.
                  Dann drei Widgets deckungsgleich übereinander legen und in die Sichtbarkeit den gewünschten Wert von x eintragen.
                  
                  Beim Widget __Bezug__ in OID die ID des (ggf. korrigierten) modbus-Datenpunktseintragen, in Sichtbarkeit die ID __javascript.0.Displayzaehler__ und als Wert die ==0.
                  
                  Beim Widget __PVLeistung__ den entsprechenden Datenpunkt, in Sichtbarkeit wieder die ID __javascript.0.Displayzaehler__ und als Wert die ==1.
                  
                  Beim Widget __Einspeisung__ schließlich den richtigen Datenpunkt, in Sichtbarkeit die ID __javascript.0.Displayzaehler__ und als Wert die ==2.
                  
                  Zwei der drei Widgets werden jetzt im Minutentakt für eine Minute ausgeblendet, es bleibt ein Widget mit stets aktuellen Daten.
                  
                  Gruß,
                  
                  Pix
                  1 Reply Last reply Reply Quote 0
                  • M
                    Marcolotti last edited by

                    Guten Morgen,

                    vielen Dank für eure Antworten.

                    Ich habe das jetzt mit dem Interval und den 3 deckungsgleichen Anzeigen gemacht. Das funktioniert soweit ganz gut ABER…

                    Wenn ich die 3 Widgets übereinander lege, dann sind prinzipiell immer 2 davon klein bei der Anzeige. Ich habe es über Widgets-Exportieren und Importieren gemacht, alle Werte verglichen, alle 3 zusammen markiert und nochmals die Werte (Größenangaben) neu geschrieben. Trotzdem sind immer 2 davon in klein, das letzte ist groß.

                    721_pv.jpg
                    721_einspeisung.jpg
                    721_bezug.jpg

                    VIS Edit
                    721_vis.jpg

                    Vielen Dank und viele Grüße

                    Marco

                    1 Reply Last reply Reply Quote 0
                    • Bluefox
                      Bluefox last edited by

                      @Marcolotti:

                      Guten Morgen,

                      vielen Dank für eure Antworten.

                      Ich habe das jetzt mit dem Interval und den 3 deckungsgleichen Anzeigen gemacht. Das funktioniert soweit ganz gut ABER…

                      Wenn ich die 3 Widgets übereinander lege, dann sind prinzipiell immer 2 davon klein bei der Anzeige. Ich habe es über Widgets-Exportieren und Importieren gemacht, alle Werte verglichen, alle 3 zusammen markiert und nochmals die Werte (Größenangaben) neu geschrieben. Trotzdem sind immer 2 davon in klein, das letzte ist groß.

                      filename="PV.JPG" index="1">~~
                      filename="Einspeisung.JPG" index="2">~~
                      filename="bezug.JPG" index="3">~~

                      VIS Edit
                      filename="vis.JPG" index="0">~~

                      Vielen Dank und viele Grüße

                      Marco `
                      Kannst du mal die 3 exportieren hier?

                      1 Reply Last reply Reply Quote 0
                      • M
                        Marcolotti last edited by

                        [{"tpl":"tplSegmentClock","data":{"oid":"modbus.0.inputRegisters.30865_Bezug","visibility-cond":"==","visibility-val":"1","clock":false,"seconds":false,"pattern":"#####","colorOn":"#fd1717","colorOff":"rgba(0, 0, 0, 0.1)","runStepInterval":"0","segmentCount":"7","displayAngle":"9","digitHeight":"25","digitWidth":"20","digitDistance":"2","segmentWidth":"2","segmentDistance":"0.5","cornerType":"PointedCorner","gestures-offsetX":"0","gestures-offsetY":0,"gestures-swiping-value":"","gestures-rotating-value":"","gestures-pinching-value":"","gestures-swipeRight-value":"","gestures-swipeLeft-value":"","gestures-swipeUp-value":"","gestures-swipeDown-value":"","gestures-rotateLeft-value":"","gestures-rotateRight-value":"","gestures-pinchIn-value":"","gestures-pinchOut-value":"","text":"","locked":false,"visibility-oid":"javascript.0.Displayzaehler"},"style":{"left":"796px","top":"6px","width":"334px","height":"92px","text-align":"","color":"#fd0808"},"widgetSet":"timeandweather"},{"tpl":"tplSegmentClock","data":{"oid":"modbus.0.inputRegisters.30775_PVLeistung","visibility-cond":"==","visibility-val":"2","clock":false,"seconds":false,"pattern":"#####","colorOn":"#fd1717","colorOff":"rgba(0, 0, 0, 0.1)","runStepInterval":"0","segmentCount":"7","displayAngle":"9","digitHeight":"25","digitWidth":"20","digitDistance":"2","segmentWidth":"2","segmentDistance":"0.5","cornerType":"PointedCorner","gestures-offsetX":"0","gestures-offsetY":0,"gestures-swiping-value":"","gestures-rotating-value":"","gestures-pinching-value":"","gestures-swipeRight-value":"","gestures-swipeLeft-value":"","gestures-swipeUp-value":"","gestures-swipeDown-value":"","gestures-rotateLeft-value":"","gestures-rotateRight-value":"","gestures-pinchIn-value":"","gestures-pinchOut-value":"","text":"","locked":false,"visibility-oid":"javascript.0.Displayzaehler"},"style":{"left":"796px","top":"7px","width":"334px","height":"92px","text-align":"","color":"#fd0808","font-style":"normal"},"widgetSet":"timeandweather"},{"tpl":"tplSegmentClock","data":{"oid":"modbus.0.inputRegisters.30867_Einspeisung","visibility-cond":"==","visibility-val":"3","clock":false,"seconds":false,"pattern":"#####","colorOn":"#fd1717","colorOff":"rgba(0, 0, 0, 0.1)","runStepInterval":"0","segmentCount":"7","displayAngle":"9","digitHeight":"25","digitWidth":"20","digitDistance":"2","segmentWidth":"2","segmentDistance":"0.5","cornerType":"PointedCorner","gestures-offsetX":"0","gestures-offsetY":0,"gestures-swiping-value":"","gestures-rotating-value":"","gestures-pinching-value":"","gestures-swipeRight-value":"","gestures-swipeLeft-value":"","gestures-swipeUp-value":"","gestures-swipeDown-value":"","gestures-rotateLeft-value":"","gestures-rotateRight-value":"","gestures-pinchIn-value":"","gestures-pinchOut-value":"","text":"","locked":false,"visibility-oid":"javascript.0.Displayzaehler"},"style":{"left":"798px","top":"7px","width":"334px","height":"92px","text-align":"","color":"#fd0808"},"widgetSet":"timeandweather"}]
                        
                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        1.2k
                        Online

                        31.7k
                        Users

                        79.7k
                        Topics

                        1.3m
                        Posts

                        5
                        18
                        2722
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo