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
    346

  • 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.
  • 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

                              602

                              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