Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Datenpunkte zusammenführen switch + state

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    SOLVED Datenpunkte zusammenführen switch + state

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

      @Elektroniker86 sagte:

      muss das cript so aussehen?

      Fast - es fehlt noch der Punkt hinter s70

      const idVis = 'Logo.s70.' + common.name.replace(' ', '_');
      
      1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @Elektroniker86 last edited by

        @Elektroniker86 sagte:

        kann man dieses Script auch so umschreiben das dass auch für die Rolladen funktioniert?

        Kann man.

        // IDs anpassen
        const idCmd = 's7.1.DBs.DB1.NAI01';
        const idStat = 's7.1.DBs.DB1.AM01';
         
        const js = 'system.adapter.javascript.' + instance;
        const common = getObject(idCmd).common;
        const idVis = 'LOGO.s7-1.' + common.name.replace(/\s/g, '_');
         
        common.read = true;
        createState(idVis, getState(idStat).val, common);
         
        on({id: 'javascript.0.' + idVis, change: 'ne', fromNe: js}, function(dp) {
            setState(idCmd, dp.state.val);
        });
         
        on(idStat, function(dp) {
            setState(idVis, dp.state.val, true);
        });
        
        Elektroniker86 2 Replies Last reply Reply Quote 1
        • Elektroniker86
          Elektroniker86 last edited by Elektroniker86

          @Elektroniker86 sagte in Datenpunkte zusammenführen switch + state:

                                                                                                                                      // IDs anpassen                                                                                                        const idButton = 's7.0.abc.NI19';                                                                                                        const idActor = 's7.0.xyz.Q19';                                                                                                                                                                                                                 const js = 'system.adapter.javascript.' + instance;                                                                                                        const common = getObject(idButton).common;                                                                                                        const idVis = 'Logo.s70' + common.name.replace(' ', '_');                                                                                                                                                                                                                 common.read = true;                                                                                                        createState(idVis, getState(idActor).val, common);                                                                                                                                                                                                                 on({id: idVis, change: 'ne', fromNe: js}, function() {                                                                                                            setState(idButton, true);                                                                                                        });                                                                                                                                                                                                                 on(idActor, function(dp) {                                                                                                            setState(idVis, dp.state.val, true);                                                                                                        });                                                                                                                                 
          

          Alles klar ja den Punkt hatte ich vergessen.
          So, ich habe eben das Script getestet soweit alles in Ordnung.
          Allerdings kann ich die Aktoren nicht über den neuen Datenpunkt schalten.
          Wenn sich der Status vom Aktor ändert dann wechselt der neue Datenpunkt entsprechend mit, passt ja.
          Aber ich muss von dem neuen Datenpunkt auch den "Aktor" /Button ansteuern können.

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

            So habe ich das jetzt eingetragen, sollte doch so passen?

            Unbenannt.png

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

              @Elektroniker86 sagte:

              kann ich die Aktoren nicht über den neuen Datenpunkt schalten.

              Das soll in Zeilen 13 bis 15 passieren: Tastendruck, wenn sich der Wert ändert, außer die Änderung erfolgt aus dem Skript. Füge mal vor Zeile 14 ein Log ein:

              on({id: idVis, change: 'ne', fromNe: js}, function() {
                  log('Tastendruck');
                  setState(idButton, true);
              });
              
              Elektroniker86 2 Replies Last reply Reply Quote 0
              • Elektroniker86
                Elektroniker86 @paul53 last edited by

                @paul53 sagte in Datenpunkte zusammenführen switch + state:

                                                                                                                                            on({id: idVis, change: 'ne', fromNe: js}, function() {                                                                                                                                                                                log('Tastendruck');                                                                                                                                                                                setState(idButton, true);                                                                                                                                                                            });                                            
                
                // IDs anpassen
                const idButton = 's7.0.DBs.DB1.NI02';
                const idActor = 's7.0.DBs.DB1.Q02';
                 
                const js = 'system.adapter.javascript.' + instance;
                const common = getObject(idButton).common;
                const idVis = 'LOGO.s7-0.' + common.name.replace(' ', '_');
                 
                common.read = true;
                createState(idVis, getState(idActor).val, common);
                 
                on({id: idVis, change: 'ne', fromNe: js}, function() {
                    setState(idButton, true);on({id: idVis, change: 'ne', fromNe: js}, function() {
                    log('Tastendruck');
                    setState(idButton, true);
                });
                
                });
                 
                on(idActor, function(dp) {
                    setState(idVis, dp.state.val, true);
                });
                 
                
                

                So?

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

                  @Elektroniker86 sagte:

                  So?

                  Nein, so:

                  // IDs anpassen
                  const idButton = 's7.0.DBs.DB1.NI02';
                  const idActor = 's7.0.DBs.DB1.Q02';
                   
                  const js = 'system.adapter.javascript.' + instance;
                  const common = getObject(idButton).common;
                  const idVis = 'LOGO.s7-0.' + common.name.replace(' ', '_');
                   
                  common.read = true;
                  createState(idVis, getState(idActor).val, common);
                   
                  on({id: idVis, change: 'ne', fromNe: js}, function() {
                      log('Tastendruck');
                      setState(idButton, true);
                  });
                   
                  on(idActor, function(dp) {
                      setState(idVis, dp.state.val, true);
                  });
                  
                  1 Reply Last reply Reply Quote 0
                  • Elektroniker86
                    Elektroniker86 last edited by

                    Javascript spuckt das im Log aus::

                    13:48:51.637 info javascript.0 Stop script script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten
                    13:48:51.657 info javascript.0 Start javascript script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten
                    13:48:51.658 info javascript.0 script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten: registered 2 subscriptions and 0 schedules
                    13:48:58.646 info javascript.0 Stop script script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten
                    13:49:01.052 info javascript.0 Start javascript script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten
                    13:49:01.053 info javascript.0 script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten: registered 2 subscriptions and 0 schedules

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

                      @Elektroniker86 sagte:

                      Javascript spuckt das im Log aus:

                      Hast Du den Wert des Datenpunktes geändert (z.B. in Vis). Nur dann erscheint "Tastendruck" im Log.

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

                        Im Vis habe ich noch überhaupt nichts geändert. Ich habe jetzt nur erst mal zum test ein Script angelegt und das ganze teste ich unter objekte .... Javascript.LOGO.s7-0.

                        Wenn es in Objekte Funktioniert, dann muss der Rest auch funktionieren oder nicht?

                        Wenn ich am neuen Datenpunkt z.B auf true klicke dann wird die Button ID nicht angesteuert.

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

                          @Elektroniker86 sagte:

                          es reicht den Taster Datenpunkt einmal auf true zu setzen.
                          Danach springt er nach einer Sekunde automatisch wieder auf false.

                          Das passierte wohl im Szene-Adapter ? Dann muss dieses Verhalten auch im Skript erzeugt werden.

                          // IDs anpassen
                          const idButton = 's7.0.DBs.DB1.NI02';
                          const idActor = 's7.0.DBs.DB1.Q02';
                           
                          const js = 'system.adapter.javascript.' + instance;
                          const common = getObject(idButton).common;
                          const idVis = 'LOGO.s7-0.' + common.name.replace(' ', '_');
                           
                          common.read = true;
                          createState(idVis, getState(idActor).val, common);
                           
                          on({id: idVis, change: 'ne', fromNe: js}, function() {
                              log('Tastendruck');
                              setState(idButton, true);
                              setTimeout(function() {
                                  setState(idButton, false);
                              }, 500);
                          });
                           
                          on(idActor, function(dp) {
                              setState(idVis, dp.state.val, true);
                          });
                          
                          
                          1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 @Elektroniker86 last edited by paul53

                            @Elektroniker86 sagte:

                            Wenn es in Objekte Funktioniert, dann muss der Rest auch funktionieren oder nicht?

                            Ja.

                            @Elektroniker86 sagte in Datenpunkte zusammenführen switch + state:

                            Wenn ich am neuen Datenpunkt z.B auf true klicke dann wird die Button ID nicht angesteuert.

                            Wie stellst Du es fest ? Der Wert des Tasters ändert sich nicht, sondern nur der Zeitstempel.

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

                              Doch der wert ändert sich kurz auf true und geht wieder zurück.
                              Habe als switch deklariert ...... ahh ist das der fehler?

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

                                @Elektroniker86 sagte:

                                Habe als switch deklariert ...... ahh ist das der fehler?

                                Nein, die Rolle hat für Javascript keine Bedeutung.

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

                                  ich habe ein zweites Browserfenster auf gemacht und geschaut ob der Wert sich kurz ändert.
                                  Wenn ich die Button ID vom s7 direkt ansteuere dann wechselt der Datenpunkt entsprechend dem Aktorzustand. Das funktioniert soweit.

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

                                    @Elektroniker86 sagte:

                                    ich habe ein zweites Browserfenster auf gemacht und geschaut ob der Wert sich kurz ändert.

                                    Wenn Du den Wert des Datenpunktes javascript.0.s7... änderst, muss eine Tastenbetätigung erfolgen (Logausgabe im anderen Fenster).

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

                                      Mhh,

                                      im Log kommt nur das :

                                      javascript.0 2019-10-24 14:20:44.995 info script.js.common.Speedtest.Internet_Speedtest: Speedtest Daten aktualisiert
                                      javascript.0 2019-10-24 14:18:22.025 info script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten: registered 2 subscriptions and 0 schedules
                                      javascript.0 2019-10-24 14:18:22.020 info Start javascript script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten
                                      javascript.0 2019-10-24 14:18:20.632 info Stop script script.js.common.LOGO.s7-0.Deckenleuchte_Zimmer_KG_hinten

                                      Beim wechseln vom #Datenpunkt passiert nichts im Log

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

                                        Anmerkung 2019-10-24 142404.png

                                        Anmerkung 2019-10-24 142505.png

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

                                          @Elektroniker86 sagte:

                                          im Log kommt nur das :

                                          Dann funktioniert der Trigger nicht.
                                          Ändere mal den Trigger (Zeile 12) in

                                          on({id: 'javascript.0.' + idVis, change: 'ne', fromNe: js}, function() {
                                          
                                          1 Reply Last reply Reply Quote 1
                                          • Elektroniker86
                                            Elektroniker86 last edited by

                                            @paul53 sagte in Datenpunkte zusammenführen switch + state:

                                            on({id: 'javascript.0.' + idVis, change: 'ne', fromNe: js}, function() {

                                            MEGA!!!

                                            Jetzt funktioniert es !!! 😊

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

                                              Genau so soll es funktionieren.
                                              Vielen lieben Dank für den tollen Support !!!
                                              Der Rest sollte jetzt kein Problem mehr sein.
                                              Jetzt kann ich alles ändern und den Szenenadapter entfernen. Klasse!

                                              1 Reply Last reply Reply Quote 0
                                              • First post
                                                Last post

                                              Support us

                                              ioBroker
                                              Community Adapters
                                              Donate
                                              FAQ Cloud / IOT
                                              HowTo: Node.js-Update
                                              HowTo: Backup/Restore
                                              Downloads
                                              BLOG

                                              428
                                              Online

                                              31.8k
                                              Users

                                              80.0k
                                              Topics

                                              1.3m
                                              Posts

                                              datenpunkte objekte s7.0
                                              3
                                              55
                                              3503
                                              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