Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. IP-Cam View aktivieren durch Trigger

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    16
    1
    347

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.8k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

IP-Cam View aktivieren durch Trigger

Geplant Angeheftet Gesperrt Verschoben Visualisierung
20 Beiträge 6 Kommentatoren 2.8k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • PeoplesP Offline
    PeoplesP Offline
    Peoples
    schrieb am zuletzt editiert von
    #2

    Ob das funktioniert kann ich dir nicht sagen, aber du könntest die Cam in einer Separaten Seite einbinden und die View automatisch auf diese wechseln das geht

    Ich beantworte keine Fragen zu Themen via PN

    1 Antwort Letzte Antwort
    0
    • smartboartS Offline
      smartboartS Offline
      smartboart
      schrieb am zuletzt editiert von
      #3

      Ich habe das auch ueber eine separate view gelöst..Wo alle Kamerabilder eingebunden sind… Ob das mit einem widget geht ist ne gute Frage.. HÄtte mich auch interessiert

      Gesendet von meinem CLT-L09 mit Tapatalk

      1 Antwort Letzte Antwort
      0
      • M Offline
        M Offline
        mikiline
        schrieb am zuletzt editiert von
        #4

        Mach ein Extra Widget mit Sichtbarkeit auf false (unsichtbar) und setze die Sichtbarkeit nur auf true wenn dein Trigger ausgelöst hat.

        1 Antwort Letzte Antwort
        0
        • H Offline
          H Offline
          hansmeier
          schrieb am zuletzt editiert von
          #5

          Wie funktioniert das mit dem Extra Widget (welches genau) und der Sichtbarkeit ? So einen Parameter habe ich bisher nicht gefunden.

          Edit: Habe den Vorschlag nun mit einem Image-Widget hinbekommen. Allerdings erscheint das Kamera-Bild erst nach ca. 10 Sekunden. Testweise getriggert habe ich auf eine Hue-Lampe. Der Hue-Aapter hat ein Pollintervall von 3 Sekunden.

          1 Antwort Letzte Antwort
          0
          • H Offline
            H Offline
            hansmeier
            schrieb am zuletzt editiert von
            #6

            @peoples:

            Ob das funktioniert kann ich dir nicht sagen, aber du könntest die Cam in einer Separaten Seite einbinden und die View automatisch auf diese wechseln das geht `

            Wie funktioniert das automatische Wechseln auf eine eigene View ? Die spezielle View für die Cam ist schon vorhanden.

            1 Antwort Letzte Antwort
            0
            • H Offline
              H Offline
              hansmeier
              schrieb am zuletzt editiert von
              #7

              @smartboart:

              Ich habe das auch ueber eine separate view gelöst..Wo alle Kamerabilder eingebunden sind… Ob das mit einem widget geht ist ne gute Frage.. HÄtte mich auch interessiert `

              Man müsste also den Klick bzw. Fingertip auf ein Widget simulieren. Das ist letztendlich die Fragestellung.

              Wäre doch schön, wenn es klingelt, dass dann am Tablet im Flur das Popup Fenster sich öffnet und die IP-Cam an der Haustür ein Bild liefert.

              1 Antwort Letzte Antwort
              0
              • smartboartS Offline
                smartboartS Offline
                smartboart
                schrieb am zuletzt editiert von
                #8

                Das mit dem widget wird nicht so ohne weiteres gehen. iobroker vis dagegen legt objekt id's an welche man per Script setzen kann.. Beim view Wechsel in vis siehst du was mit den Objekten passiert. Die Objekte sind beschreibbar also kannst du das nachstellen… Jede installierte vis app hat eine eigene ID. Also kann auch zwischen den Endgeräten unterschieden werden...

                Wie das geht findest du hier im forum... Wenn ich zu Hause bin kann ich auch ein Beispiel anhängen... Gibt's aber hier schon....

                Gesendet von meinem CLT-L09 mit Tapatalk

                1 Antwort Letzte Antwort
                0
                • H Offline
                  H Offline
                  hansmeier
                  schrieb am zuletzt editiert von
                  #9

                  Danke. Das konnte ich soweit nachvollziehen in dem Vis-Adapter unter "Control vis". Das bringt mich schon mal weiter.

                  Ein Beispiel - Script oder ein Link wäre klasse !

                  1 Antwort Letzte Antwort
                  0
                  • smartboartS Offline
                    smartboartS Offline
                    smartboart
                    schrieb am zuletzt editiert von
                    #10

                    Hier ein Beispiel von mir bei Anruf…Der Viewwechsel ist bei mir noch Verriegelt falls ein Alarm ansteht...

                    In diesem Beispeil werden alle Endgeräte bei anruf auf die wiew fritzwlanbox umgestell wenn kein alarm ansteht.

                    //  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');
                      }
                    });
                    
                    J 1 Antwort Letzte Antwort
                    0
                    • H Offline
                      H Offline
                      hansmeier
                      schrieb am zuletzt editiert von
                      #11

                      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 Antwort Letzte Antwort
                      0
                      • smartboartS Offline
                        smartboartS Offline
                        smartboart
                        schrieb am zuletzt editiert von
                        #12

                        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 Antwort Letzte Antwort
                        0
                        • smartboartS Offline
                          smartboartS Offline
                          smartboart
                          schrieb am zuletzt editiert von
                          #13

                          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 Antwort Letzte Antwort
                          0
                          • H Offline
                            H Offline
                            hansmeier
                            schrieb am zuletzt editiert von
                            #14

                            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 Antwort Letzte Antwort
                            0
                            • smartboartS Offline
                              smartboartS Offline
                              smartboart
                              schrieb am zuletzt editiert von
                              #15

                              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 Antwort Letzte Antwort
                              0
                              • smartboartS smartboart

                                Hier ein Beispiel von mir bei Anruf…Der Viewwechsel ist bei mir noch Verriegelt falls ein Alarm ansteht...

                                In diesem Beispeil werden alle Endgeräte bei anruf auf die wiew fritzwlanbox umgestell wenn kein alarm ansteht.

                                //  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');
                                  }
                                });
                                
                                J Offline
                                J Offline
                                Jeek
                                schrieb am zuletzt editiert von
                                #16

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

                                smartboartS 1 Antwort Letzte Antwort
                                0
                                • J Jeek

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

                                  smartboartS Offline
                                  smartboartS Offline
                                  smartboart
                                  schrieb am zuletzt editiert von
                                  #17

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

                                  J 1 Antwort Letzte Antwort
                                  0
                                  • smartboartS smartboart

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

                                    J Offline
                                    J Offline
                                    Jeek
                                    schrieb am zuletzt editiert von
                                    #18

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

                                    smartboartS 1 Antwort Letzte Antwort
                                    0
                                    • J Jeek

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

                                      smartboartS Offline
                                      smartboartS Offline
                                      smartboart
                                      schrieb am zuletzt editiert von
                                      #19

                                      @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 Antwort Letzte Antwort
                                      0
                                      • M Offline
                                        M Offline
                                        maze007
                                        schrieb am zuletzt editiert von
                                        #20

                                        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 Antwort Letzte Antwort
                                        0
                                        Antworten
                                        • In einem neuen Thema antworten
                                        Anmelden zum Antworten
                                        • Älteste zuerst
                                        • Neuste zuerst
                                        • Meiste Stimmen


                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        501

                                        Online

                                        32.7k

                                        Benutzer

                                        82.5k

                                        Themen

                                        1.3m

                                        Beiträge
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                        ioBroker Community 2014-2025
                                        logo
                                        • Anmelden

                                        • Du hast noch kein Konto? Registrieren

                                        • Anmelden oder registrieren, um zu suchen
                                        • Erster Beitrag
                                          Letzter Beitrag
                                        0
                                        • Home
                                        • Aktuell
                                        • Tags
                                        • Ungelesen 0
                                        • Kategorien
                                        • Unreplied
                                        • Beliebt
                                        • GitHub
                                        • Docu
                                        • Hilfe