Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Bild unter vis.0 aktualisiert nicht

    NEWS

    • Amazon Alexa - ioBroker Skill läuft aus ?

    • Monatsrückblick – September 2025

    • Neues Video "KI im Smart Home" - ioBroker plus n8n

    Bild unter vis.0 aktualisiert nicht

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

      @coyote

      dafür ist doch der letzte Abschnitt wichtig .

      111111111111111111111111111111111111.JPG

      Teste das Script doch mal 😉

      coyote 1 Reply Last reply Reply Quote 0
      • apollon77
        apollon77 @coyote last edited by

        @coyote dann nimm den Vis Dateimanager und lade es dort hoch. Dafür ist der da.

        Homoran coyote 2 Replies Last reply Reply Quote 0
        • Homoran
          Homoran Global Moderator Administrators @apollon77 last edited by

          @apollon77 sagte in Bild unter vis.0 aktualisiert nicht:

          @coyote dann nimm den Vis Dateimanager und lade es dort hoch. Dafür ist der da.

          Bei dynamisch erzeugten Bildern (hier: Snapshot der Cam) nicht immer einfach 😉

          1 Reply Last reply Reply Quote 0
          • coyote
            coyote Most Active @apollon77 last edited by

            @apollon77 na wie soll ich dass denn machen?😵
            Wie homoran schon schrieb, bei dynamischen wird das eher schwierig

            1 Reply Last reply Reply Quote 0
            • S
              saeft_2003 Most Active last edited by

              man kann doch bestimmt irgendwie ein Bild aus dem Ordner home/iobroker/ in der VIS anzeigen, oder nicht? Weil dann speichere ich eben dort meine dynamischen Snapshots...

              1 Reply Last reply Reply Quote 0
              • Ralla66
                Ralla66 Most Active last edited by Ralla66

                @coyote
                Soll ja jeder machen wie er meint.
                Wäre mir zu aufwendig.
                Hab mir einen 2 ten Pi gegönnt auf dem Motioneye läuft.
                Bilder oder Http Stream abholen ist dann kein Problem mehr.
                Zumal das leidige Thema RTSP Stream damit auch erledigt ist.

                Dann brauchste das Bild nicht zwischen speichern sondern holst das direkt von der Cam
                ab wenn getriggert wird.

                1 Reply Last reply Reply Quote 0
                • coyote
                  coyote Most Active @Glasfaser last edited by

                  @Glasfaser danke, habe erst im falschen Script geschaut, funktioniert tatsächlich. Habe es noch schnell an meine Bedürfnisse angepasst, brauche ja nur ein Bild.

                  @Ralla66 bei mir läuft alles über einen bzw. zwei Nuc's somit wäre das, das geringste Problem, ich bin da aber noch an Zoneminder testen.
                  Aber habe ich es richtig verstanden, du zeigst direkt ab trigger, dann den Snapshot Pfad der Cam an, korrekt?
                  Welches Widget? Iframe?

                  Glasfaser 1 Reply Last reply Reply Quote 0
                  • coyote
                    coyote Most Active last edited by

                    @apollon77 was mich jetzt aber interessieren würde ist, warum ein direktes fs.writeFile nach vis.0 nicht geht, sondern erst nach /tmp dann ein fs.readFileSync des temporären Bildes von /tmp und dann writeFile nach vis.0 🤔

                    apollon77 1 Reply Last reply Reply Quote 0
                    • Glasfaser
                      Glasfaser @coyote last edited by

                      @coyote

                      Bitteschön 🙂

                      1 Reply Last reply Reply Quote 0
                      • Ralla66
                        Ralla66 Most Active last edited by Ralla66

                        @coyote
                        In meiner Vis läuft immer die Live Cam.
                        Bei Alarm schaltet die Visu auf Kamera View um.

                        Wenn Alarmanlage ist ein und ein Fenster / Tür Kontakt wird aktiviert,
                        wird vom IO / Blockly das MotionEye Live Bild geholt und dierkt per E-Mail Adapter versandt.

                        Zwischenspeichern des Bildes benötige ich nicht.
                        So als Anregung das es auch anders geht.

                        MotionEye_100220.jpg

                        coyote 1 Reply Last reply Reply Quote 0
                        • coyote
                          coyote Most Active @Ralla66 last edited by

                          @Ralla66 achso ok, darum ging es mir ja nicht, dass mache ich über telegram und in der Visu läuft auch der Stream. Ich will ja zb beim klingeln oder Posteinwurf den letzten Snapshot in der Visu anzeigen, wenn ich auf ein Icon klicke. Aber funktioniert ja jetzt.

                          S 1 Reply Last reply Reply Quote 0
                          • S
                            saeft_2003 Most Active @coyote last edited by

                            @coyote

                            ehrlich gesagt komm ich nicht mehr ganz mit. was genau hast du jetzt getan damit es wieder geht?

                            Glasfaser coyote 2 Replies Last reply Reply Quote 0
                            • Glasfaser
                              Glasfaser @saeft_2003 last edited by

                              @saeft_2003

                              @Glasfaser sagte in [Frage BLOCKLY ] Klingel Bild per Telegram versenden / Snapshot von Cam per Telegram versenden:

                              @Knallochse

                              Ich habe das hier so bei mir angepasst (Vorlage von Chaot) :

                              Es werde 4 Screenshot´s erstellt , per Telegramm versendet und in vis.0/klingelbild zur weiteren Verwendung hinterlegt .

                              Datenpunkt in const idklingel und die vier URL anpassen .

                              const idklingel = ["hm-rpc.2.00145709AED72D.8.PRESS_SHORT", "hm-rpc.2.00145709AED72D.8.PRESS_LONG", "ID5", "ID4"];
                              
                              var sperre = false;  //verhindert das doppeltes Drücken das Script stoppt
                              
                              var timeout1, timeout2, timeout3, timeout4, timeout5, timeout6, timeout7, timeout8, timeout9, timeout10, timeout11;
                              
                              var fs = require('fs');
                              
                              
                              
                              
                              on({id: idklingel, change: "any"}, function (obj) {
                              
                               if(!sperre) {
                              
                                 sperre = true;
                              
                                 
                              
                                  // Speichert das erste Bild bei Klingeln
                              
                                 exec('wget --output-document /tmp/haustuer1.jpg \'http://user:passwort@192.168.178.53/streaming/channels/101/picture\'');
                              
                                 
                                  // Nach dem ersten Bild wird nach 2000ms das nächste Bild gespeichert
                                 timeout1 = setTimeout(function () {
                              
                                   exec('wget --output-document /tmp/haustuer2.jpg \'http://user:passwort@192.168.178.53/streaming/channels/101/picture\''); 
                              
                                 }, 2000);
                              
                                 
                                  // Nach dem zweiten Bild wird nach 2000ms das nächste Bild gespeichert
                                 timeout2 = setTimeout(function () {
                              
                                   exec('wget --output-document /tmp/haustuer3.jpg \'http://user:passwort@192.168.178.53/streaming/channels/101/picture\'');
                              
                                 }, 4000);
                              
                                
                                  // Nach dem dritten Bild wird nach 2000ms das nächste Bild gespeichert
                                 timeout3 = setTimeout(function () {
                              
                                   exec('wget --output-document /tmp/haustuer4.jpg \'http://user:passwort@192.168.178.53/streaming/channels/101/picture\'');
                              
                                 }, 6000);
                              
                              
                                  // Telegram versenden
                                 timeout4 = setTimeout(function(){
                              
                                     sendTo('telegram.0', {text: '/tmp/haustuer1.jpg', caption: 'Jemand klingelt an der Haustür !!!'});
                              
                                             //log ('__ Klingel-Bild wurde versendet __');
                              
                                 }, 8000); 
                                 timeout5 = setTimeout(function(){
                              
                                     sendTo('telegram.0', {text: '/tmp/haustuer2.jpg', caption: 'Jemand klingelt an der Haustür !!!'});
                              
                                             //log ('__ Klingel-Bild wurde versendet __');
                              
                                 }, 9000); 
                              
                              
                                 }
                                        
                              
                                 timeout6 = setTimeout(function() {
                              
                                    sperre = false;
                              
                                 }, 5000); //Zeit für Klingelsperre 1.Zeile
                              
                              
                                  // Bilder werden nach vis gespeichert
                                 timeout7 = setTimeout(function () {
                              
                                      const bild1 = fs.readFileSync('/tmp/haustuer1.jpg');
                              
                                      writeFile('vis.0','/klingelbild/haustuer1.jpg', bild1);
                              
                                      const bild2 = fs.readFileSync('/tmp/haustuer2.jpg');
                              
                                      writeFile('vis.0','/klingelbild/haustuer2.jpg', bild2);
                              
                                      const bild3 = fs.readFileSync('/tmp/haustuer3.jpg');
                              
                                      writeFile('vis.0','/klingelbild/haustuer3.jpg', bild3);
                              
                                      const bild4 = fs.readFileSync('/tmp/haustuer4.jpg');
                              
                                      writeFile('vis.0','/klingelbild/haustuer4.jpg', bild4);
                              
                                 }, 20000); 
                              
                              });
                              
                              
                              
                              

                              1 Reply Last reply Reply Quote 0
                              • coyote
                                coyote Most Active @saeft_2003 last edited by

                                @saeft_2003 habe das Script aus dem Link von Glasfaser benutzt, damit geht es. Kann ich morgen Mal hochladen, habe es für mich soweit gekürzt, da ich nur ein Bild benötige.

                                S 1 Reply Last reply Reply Quote 0
                                • S
                                  saeft_2003 Most Active @coyote last edited by

                                  @coyote

                                  und du kannst jetzt das bild im vis datei manager direkt auswählen? Ja wäre nett wenn du das machst. Könnte man das auch in blockly nachbauen? weil da kenn ich mich ein wenig aus, direkt mit js leider nicht wirklich...

                                  1 Reply Last reply Reply Quote 0
                                  • apollon77
                                    apollon77 @coyote last edited by

                                    @coyote Bitte liess die Erklärungen im js.controller 2.1 Thread .. da steht alles genau drin 🙂 und da ist auch ein Thread verlinkt mit weiteren Details und Skripten.

                                    Ein kopieren in das files/vis.0 macht das File nicht im ioBroker Storage bekannt ... und damit existiert es für den ioBroker nicht. Erst mit writeFile machst Du das

                                    S coyote 2 Replies Last reply Reply Quote 0
                                    • S
                                      saeft_2003 Most Active @apollon77 last edited by

                                      @apollon77

                                      Danke für die Erklärung weißt du ob das writefile auch mit blockly möglich ist?

                                      @coyote

                                      Wäre nett wenn du heute im laufe des Tages mal dein script zu Verfügung stellen könntest.

                                      1 Reply Last reply Reply Quote 0
                                      • coyote
                                        coyote Most Active @apollon77 last edited by coyote

                                        @apollon77 ich wusste doch, dass ich da irgendwo mal was gelesen hatte, habe es gestern nur nicht mehr gefunden. Ich werde nochmal im js-controller thread suchen.

                                        Aber wieso kopieren? wie oben in meinem ersten Script, schreibe ich doch damit die Datei in vis oder nicht?

                                         fs.writeFile(dest_path + 'Postbild.jpeg', body, 'binary', function(err) {
                                        

                                        aber so geht es ja nicht.

                                        @saeft_2003 hier:

                                        var source_url = 'http://192.168.XX.XX:2000/cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=XXXX&pwd=XXXX',
                                            dest_path = '/opt/iobroker/iobroker-data/files/vis.0/';
                                        
                                        
                                        var request = require("request");
                                        var fs      = require('fs');
                                        
                                            // Speichert das erste Bild 
                                        function saveImage(){
                                            request.get({url: source_url, encoding: 'binary'}, function (err, response, body) {
                                                fs.writeFile('/tmp/' + 'Postbild.jpg', body, 'binary', function(err) {
                                          if (err) {
                                                    log('Fehler beim Bild speichern: ' + err, 'warn');
                                                } else {
                                                    log('Webcam Bild gespeichert');  
                                                }
                                                })
                                            })
                                            // Bilder werden nach vis gespeichert
                                                const bild1 = fs.readFileSync('/tmp/Postbild.jpg');
                                                writeFile('vis.0','/Postbild.jpg', bild1);
                                        };
                                        

                                        EDIT; @apollon77 habs gefunden, auch die Links dazu, wo es besprochen wurde. Danke

                                        S 1 Reply Last reply Reply Quote 0
                                        • S
                                          saeft_2003 Most Active @coyote last edited by

                                          @coyote

                                          Danke fürs skript werde ich heute Abend testen. Aber wie gesagt da ich in js nicht wirklich fitt bin könnte es sein das ich noch die ein oder andere Frage habe...

                                          coyote 1 Reply Last reply Reply Quote 0
                                          • coyote
                                            coyote Most Active @saeft_2003 last edited by

                                            @saeft_2003 Klar, kein Thema sag Bescheid

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            32.3k
                                            Users

                                            81.0k
                                            Topics

                                            1.3m
                                            Posts

                                            vis
                                            6
                                            39
                                            3194
                                            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