Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Gelöst] Rauchmelder Alarm per NodeJS Socket

    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

    [Gelöst] Rauchmelder Alarm per NodeJS Socket

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

      Was hast du denn für rauchender im Einsatz? Das schreibst du leider nicht 😉

      1 Reply Last reply Reply Quote 0
      • U
        uzulio last edited by

        @apollon77:

        Was hast du denn für rauchender im Einsatz? Das schreibst du leider nicht 😉 `

        Im Eifer des Gefechts ganz vergessen :oops:

        Habe aktuell 3 Homematic IP Rauchmelder HmIP-SWSD im Einsatz.

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

          @uzulio:

          Wenn ich direkt mit den Alarm-Variablen der Rauchmelder arbeite, bekomme ich beim ersten Alarm eine Nachricht, aber auch die Nachrichten der anderen Rauchmelder, die halt sagen, dass sie keinen Alarm haben. `
          Wie hast Du das angestellt ?

          1 Reply Last reply Reply Quote 0
          • U
            uzulio last edited by

            @paul53:

            Wie hast Du das angestellt ? `

            Naja ich habe eine Variable, die den Status aller Rauchmelder beinhaltet und gehe die bei Änderung mit einer each-Funktion durch. Damit kann ich es ja nicht vermeiden, dass das passiert. Daher meine Frage.

            Natürlich könnte ich das jetzt für jeden einzeln machen, aber in Zukunft sollen noch mehr dazu kommen und dann wird das ein wenig lästig und ich hatte gehofft ich kann das irgendwie zusammenlegen.

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

              @uzulio:

              Naja ich habe eine Variable, die den Status aller Rauchmelder beinhaltet und gehe die bei Änderung mit einer each-Funktion durch. `
              Also eine https://github.com/ioBroker/ioBroker.javascript/blob/master/doc/en/javascript.md#–-selector ? Darauf kann man auch on() anwenden.

              const alleRM = $(...);
              
              alleRM.on(function(dp) {
                 var msg = dp.deviceName + ': Alarm ';
                 if(dp.state.val) msg = msg + 'kommend !';
                 else msg = msg + 'gehend';
                 // msg versenden
              });
              

              Mit on() wird nur der auslösende Datenpunkt ausgewertet.

              1 Reply Last reply Reply Quote 0
              • U
                uzulio last edited by

                @paul53:

                const alleRM = $(...);
                alleRM.on(function(dp) {
                   var msg = dp.deviceName + ': Alarm ';
                   if(dp.state.val) msg = msg + 'kommend !';
                   else msg = msg + 'gehend';
                   // msg versenden
                });
                

                Mit on() wird nur der auslösende Datenpunkt ausgewertet. `

                Aber das hilft mir doch nicht, oder? Jeder Rauchmelder hat ja entweder 0 oder 1 als state. Wenn ich mich nicht täusche würde doch bei deinem Codebeispiel ein Alarm auf Rauchmelder 1 kommen und die Ausgabe wäre "Alarm kommend". Rauchmelder 2 und 3 würden doch jetzt aber gleichzeitig auch "Alarm gehend" ausgeben. Das ist doch genau das was ich vermeiden will.

                Oder verstehe ich etwas falsch?

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

                  @uzulio:

                  Rauchmelder 2 und 3 würden doch jetzt aber gleichzeitig auch "Alarm gehend" ausgeben. `
                  Nein. Es wird nur der gerade triggernde Datenpunkt in der Callback-Funktion ausgewertet. Probier es aus !

                  1 Reply Last reply Reply Quote 0
                  • U
                    uzulio last edited by

                    Tatsächlich :roll: Vielen Dank!

                    Also war der einzige Fehler die each-Funktion zu nutzen oder wie darf ich das verstehen? Bis auf das habe ich es quasi genauso probiert vorher.

                    Edit:

                    Für den Fall, dass man noch den Raum mit abfragen möchte:

                    var raum = getObject(dp.channelId, 'rooms').enumNames
                    
                    1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 last edited by

                      @uzulio:

                      Also war der einzige Fehler die each-Funktion zu nutzen oder wie darf ich das verstehen? `
                      Ja, each() fragt alle Datenpunkte in einer Schleife ab.

                      1 Reply Last reply Reply Quote 0
                      • U
                        uzulio last edited by

                        Alles klar, dann bedanke ich mich für die schnelle Hilfe 😄

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        797
                        Online

                        31.7k
                        Users

                        79.9k
                        Topics

                        1.3m
                        Posts

                        3
                        11
                        801
                        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