Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. IP-Cam View aktivieren durch Trigger

    NEWS

    • Neues Video über Aliase, virtuelle Geräte und Kategorien

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    IP-Cam View aktivieren durch Trigger

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

      Danke, habe ich so für meine Zwecke umsetzten können: Bei Triggersignal wird nun der IP-Cam-View aufgerufen.

      Dabei ist mir aufgefallen:

      • Die Verzögerung bis der CAM-View kommt, ist unterschiedlich lang. Meist aber zu lang. Bis zu 10 Sekunden. Wovon ist das abhängig ?

      • Wie wechselt man automatisch zurück? z.B. nach x Sekunden oder wenn der Trigger false ist. Im Moment hole ich nach einem Triggerereignis die Standardview per Tastendruck zurück.

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

        sollte sofort wechseln sobald der trigger aktiv ist. da ist keine zeit drinne..

        //  viewwechsel bei Anruf
        
        on({id: 'fritzbox.0.calls.ring'}, function (obj) {
          var value = obj.state.val;
          var Alarm = getState('javascript.0.alarm.out.alarm_silent').val;
          if(obj.state.val && Alarm === false){
              console.log('Wiewwechsel bei Anruf');
            setState("vis.0.control.instance"/*Control vis*/, 'FFFFFFFF');
            setState("vis.0.control.data"/*Data for control vis*/, 'fritzWlanBox');
            setState("vis.0.control.command"/*Command for vis*/, 'changeView');
            setStateDelayed("vis.0.control.instance"/*Control vis*/, 'FFFFFFFF',120*1000);//2min 120*1000ms
            setStateDelayed("vis.0.control.data"/*Data for control vis*/, 'fritzWlanBox',120*1000); //2min Honme view eintragen wohin zurück geschaltet wird
            setStateDelayed("vis.0.control.command"/*Command for vis*/, 'changeView',120*1000); //2min - 120 * 1000ms
          }
          });
        
        
        1 Reply Last reply Reply Quote 0
        • smartboart
          smartboart last edited by

          Für meine Klingel und Bewegungsmelder habe ich jeweils ein schönes Script von Ohula angepasst.

          Es speichert die Bilder wechselt die view schickt push nachrichten mit Bilder per telegramm usw…..

          klingeln tuts nur wenn jemand zu Hause und push nachrichten wenn niemand zu hause. Viewwechsel auch nur wenn jemand zu Hause.

          1 Reply Last reply Reply Quote 0
          • H
            hansmeier last edited by

            Könntest du das Script und/oder das Basis-Script von Ohula zur Verfügung stellen ? Die Push Nachricht brauche ich zwar nicht, aber sonst klingt das so, wie ich mir das im Endausbau vorgestellt habe ! Ohne viel JS Kenntnisse muss ich mich immer recht nah an eine Vorgabe halten, dann bekomme ich das schon hin 😉

            Mit Blockly komme ich deutlich besser zurecht, aber einiges geht damit wohl nicht. Der VIS.0 Adapter kann z.B. nicht angesprochen werden ?

            Danke !

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

              ich habe nur die letzten beiden Blöcke meinen Bedürfnissen angepasst…

              // -------------------------------------------------------------------------
              // Dieses Script überwaht den Zustand eines Bewegungsmelders und speichert bei
              // Aktivierung ein Bild einer Überwachnungskamera in einem Vereichnis und sendet
              // dieses via Telegram.0-Adapter. Nach 10 Sek wird ein weiteres Bild erstellt und
              // gesendet.
              // Die Speicherung der Bilder erfolgt als "Stack", d.h. das aktuellste Bild bekommt
              // immer den Suffix "0" und es werden n Bilder mit den Suffixen 1..n-1 vorgehalten
              // Uhula 2017.11
              // -------------------------------------------------------------------------
              
              // -------------------------------------------------------------------------
              // Konfiguration
              // -------------------------------------------------------------------------
                    // URL zur Kamera umn ein Image (jpg) zu erhalten
              const cam_url = "http://192.168.1.XXXXXXXXXXXXXXXXXXX";
                    // Pfadangabe für die Speicherung der Bilder, der Pfad muss existieren
              const dest_path = '/opt/iobroker/iobroker-data/files/_temp/';
                    // Anzahl der Bilder, die vorgehalten werden sollen
              const imageCountMax = 8;                
                    // Prefix für die Bildnamen
              const imageNamePre = "Tuerklingel_Eingangstür"; 
              
              // -------------------------------------------------------------------------
              // Scriptteil
              // -------------------------------------------------------------------------
              var request = require('request');
              var fs      = require('fs');
              
              // Bild an telegram schicken 
              function sendImage (path) { 
                  try {
                      var stats = fs.statSync(path);
                      var msg = formatDate(stats.birthtime,"DD.MM.YYYY hh:mm:ss") + " " + path.substring(path.lastIndexOf('/')+1);
                      sendTo('telegram.0', {
                          text:                   path,
                          caption:                msg, 
                          disable_notification:   true
                      });
                  }
                  catch(err) { if (err.code != "ENOENT") log(err); }     
              }
              
              // löscht eine Datei synchron (wartet auf das Ergebnis)
              function fsUnlinkSync(path) {
                  try {
                      var stats = fs.statSync(path);
                      try { fs.unlinkSync(path); }
                      catch(err) { if (err.code != "ENOENT") log(err); }     
                  }
                  catch(err) { if (err.code != "ENOENT") log(err); }
              }
              
              // benennt eine Datei synchron um (wartet auf das Ergebnis)
              function fsRenameSync(oldPath, newPath) {
                  try {
                      var stats = fs.statSync(oldPath);
                      try { fs.renameSync(oldPath, newPath); }
                      catch(err) { if (err.code != "ENOENT") log(err); }     
                  }
                  catch(err) { if (err.code != "ENOENT") log(err); }
              }
              
              // Bild speichern und senden
              function saveImage() {
                  // Bild imageCountMax-1 löschen
                  fsUnlinkSync( dest_path + imageNamePre + (imageCountMax-1) + ".jpg" );
                  // Bilder 0..imageCountMax-2 umbenennen
                  for (var i=imageCountMax-2; i >= 0; i-- ) { 
                      fsRenameSync(dest_path + imageNamePre + i + ".jpg", dest_path + imageNamePre + (i+1) + ".jpg"); 
                  }
                  // Bild 0 löschen
                  var fname = imageNamePre + "0.jpg";
                  fsUnlinkSync( fname );
                  // Bild holen und speichern
                  request.get({url: cam_url, encoding: 'binary'}, function (err, response, body) {
                      fs.writeFile(dest_path + fname, body, 'binary', function(err) {
                          if (err) {
                              log('Fehler beim Bild speichern: ' + err, 'warn');
                          } else {
                              // dem Filesystem 2 Sek Zeit zum Speichern lassen
                              setTimeout(function() { sendImage(dest_path + fname); }, 2000); 
                          }
                      }); 
                  });
              }
              
              // sofort ein Bild senden und nach 10 Sek erneut
              on( 'rpi2.1.gpio.13.state', function (obj) {
                  var jemandda = getState('javascript.0.Anwesenheitssteuerung.BewohnerAnwesend').val;
                  var Klingel = getState('rpi2.1.gpio.13.state').val;
                  if (jemandda === false && Klingel === false) {
                  saveImage();
                  setTimeout(function() { saveImage(); }, 10 * 1000);
                  console.log('es hat an der Haustür jemand die Klingel während Abwesenheit betätigt');
                  }else{
                      if (jemandda === true && Klingel === false) {
                  setState("tr-064.0.states.ring"/*ring*/, '**9,12');
                  setState("vis.0.control.instance"/*Control vis*/, 'FFFFFFFF');
                  setState("vis.0.control.data"/*Data for control vis*/, 'Garten');
                  setState("vis.0.control.command"/*Command for vis*/, 'changeView');
                  console.log('es hat an der Haustür jemand die Klingel während der Anwesenheit betätigt');
                  console.log('Viewwechsel bei Klingel');
                  sendTo("paw.0",'all',{send:  'say', text:  'Es klingelt an der Haustür'});
                      }   
                  }
              });
              
              
              1 Reply Last reply Reply Quote 0
              • J
                Jeek @smartboart last edited by

                @smartboart Hi, ist es möglich wenn sich der State geändert hat, also wieder auf false zurück, auf die Startview zu wechseln?

                smartboart 1 Reply Last reply Reply Quote 0
                • smartboart
                  smartboart @Jeek last edited by

                  @Jeek Klar, du kannst auch nach einer Zeit x wieder zurück schalten...

                  J 1 Reply Last reply Reply Quote 0
                  • J
                    Jeek @smartboart last edited by

                    @smartboart Wie genau mache ich das? Mit einem Befehl?

                    smartboart 1 Reply Last reply Reply Quote 0
                    • smartboart
                      smartboart @Jeek last edited by

                      @Jeek mit zeitverzögerung z.B. so

                       
                      
                      // sofort ein Bild senden und nach 10 Sek erneut
                      
                      on( 'rpi2.1.gpio.13.state', function (obj) {
                      
                          var jemandda = getState('javascript.0.Anwesenheitssteuerung.BewohnerAnwesend').val;
                      
                          var Klingel = getState('rpi2.1.gpio.13.state').val;
                      
                          if (jemandda === false && Klingel === false) {
                      
                          saveImage();
                      
                          setTimeout(function() { saveImage(); }, 10 * 1000);
                      
                          console.log('es hat an der Haustür jemand die Klingel während Abwesenheit betätigt');
                      
                          }else{
                      
                              if (jemandda === true && Klingel === false) {
                      
                          setState("tr-064.0.states.ring"/*ring*/, '**9,12');
                      
                          setState("vis.0.control.instance"/*Control vis*/, 'FFFFFFFF');
                      
                          setState("vis.0.control.data"/*Data for control vis*/, 'Garten');
                      
                          setState("vis.0.control.command"/*Command for vis*/, 'changeView');
                      
                      //nach einer Zeit wieder zurück auf die main view
                      
                          setStateDelayed("vis.0.control.instance"/*Control vis*/, 'FFFFFFFF',10*1000); //10sekunden
                      
                          setStateDaelayed("vis.0.control.data"/*Data for control vis*/, 'mainView',10*1000);
                      
                          setStateDelayed("vis.0.control.command"/*Command for vis*/, 'changeView',10*1000);
                      
                      
                      
                          console.log('es hat an der Haustür jemand die Klingel während der Anwesenheit betätigt');
                      
                          console.log('Viewwechsel bei Klingel');
                      
                          sendTo("paw.0",'all',{send:  'say', text:  'Es klingelt an der Haustür'});
                      
                              }   
                      
                          }
                      
                      });
                      
                      1 Reply Last reply Reply Quote 0
                      • M
                        maze007 last edited by

                        Ich will was ähnliches machen und habe auch schon in sämtlichen Forum und Facebook gefragt doch leider noch keine Antwort.
                        Wenn es Klingelt soll das Kamerabild für 1 Minute in einem Popup Fenstern öffnen.
                        Habe ein Schließer Kontakt was ich mit dem SonOff Basic GPIO2 und Ground verbinde. Ich habe den neuen SonOff Basic dort ist es GPIO2. Ich habe schon Espeasy drauf in in Iobroker bekommen ich wenn ich GPIO2 mit Ground brücke eine 1 und beim öffnen eine 0. Jetzt soll der Iobroker bei einer 1 ein Popup öffnen und soll das Kamera Bild für eine Minute anzeigen. Wie richte ich das ein?

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        829
                        Online

                        32.0k
                        Users

                        80.5k
                        Topics

                        1.3m
                        Posts

                        6
                        20
                        2303
                        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