Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Test Adapter onvif camera v1.x.x

    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

    Test Adapter onvif camera v1.x.x

    This topic has been deleted. Only users with topic management privileges can see it.
    • R
      Rookie50 @Marc_el_K last edited by

      @marc_el_k in was änderst du :80? Der Datenpunkt wird von der Onvif Discovery zurück gemeldet. Es wird nicht bringen es dort händisch zu ändern...
      Schick doch mal die URL mit der Du Snapshots im Browser anzeigen lassen kannst.

      Marc_el_K 1 Reply Last reply Reply Quote 0
      • Marc_el_K
        Marc_el_K @Rookie50 last edited by

        @rookie50 mit genau dieser Adresse, jedoch nicht mit der 80 sondern meinem hinterlegten Port, den ich in den Kameraeinstellungen hinterlegt habe.

        http://IP:MeinPort/api/v1/snap.cgi?chn=0

        R 1 Reply Last reply Reply Quote 0
        • R
          Rookie50 @Marc_el_K last edited by

          @marc_el_k hast Du ein Problem mit Port 80? Oder warum hast Du dort einen anderen? Stell doch in der Kamera den Port wieder auf 80 und teste es.

          Marc_el_K 1 Reply Last reply Reply Quote 0
          • Marc_el_K
            Marc_el_K @Rookie50 last edited by Marc_el_K

            @rookie50 in den Einstellungen der Kamera kann ich von 8000-9000 einen Port vergeben. Also probiere ich es Mal mit 8000

            Edit: Nein geht nicht. Im Datenpunkt steht wieder "80". Im Browser kein Bild. Ändere ich es ab auf 8000 geht es sofort

            R T 2 Replies Last reply Reply Quote 0
            • R
              Rookie50 @Marc_el_K last edited by

              @marc_el_k ein Screenshot von den Porteinstellungen wäre hilfreich. Die Kameras haben meistens mehrere Ports für unterschiedliche Dienste

              1 Reply Last reply Reply Quote 0
              • Knallochse
                Knallochse @wendy2702 last edited by

                @wendy2702 Bei mir auch so. Ab 2. Kamera geht die Anzeige nicht mehr

                wendy2702 1 Reply Last reply Reply Quote 0
                • wendy2702
                  wendy2702 @Knallochse last edited by wendy2702

                  @knallochse Danke für die Info.

                  Vielleicht hat ja noch wer eine Lösung dazu oder sind wir die einzigen die mehr als eine Kamera in VIS haben ?

                  T 1 Reply Last reply Reply Quote 0
                  • T
                    tombox @wendy2702 last edited by

                    @wendy2702 bitte für die zweite Kamera folgendes verwenden

                    <input
                      type="hidden"
                      name="webrtc2-url"
                      id="webrtc2-url"
                      value="http://192.168.0.2:8083/stream/ddbdb583-9f80-4b61-bafa-613aa7a5daa5/channel/0/webrtc"
                    />
                     
                    <video id="webrtc2-video" autoplay muted playsinline controls style="max-width: 100%; max-height: 100%;"></video>
                    
                    setTimeout(function () {
                      function startPlay(videoEl, url) {
                        const webrtc = new RTCPeerConnection({
                          iceServers: [
                            {
                              urls: ["stun:stun.l.google.com:19302"],
                            },
                          ],
                          sdpSemantics: "unified-plan",
                        });
                        webrtc.ontrack = function (event) {
                          console.log(event.streams.length + " track is delivered");
                          videoEl.srcObject = event.streams[0];
                          videoEl.play();
                        };
                        webrtc.addTransceiver("video", { direction: "sendrecv" });
                        webrtc.onnegotiationneeded = async function handleNegotiationNeeded() {
                          const offer = await webrtc.createOffer();
                     
                          await webrtc.setLocalDescription(offer);
                     
                          fetch(url, {
                            method: "POST",
                            body: new URLSearchParams({ data: btoa(webrtc.localDescription.sdp) }),
                          })
                            .then((response) => response.text())
                            .then((data) => {
                              try {
                                webrtc.setRemoteDescription(new RTCSessionDescription({ type: "answer", sdp: atob(data) }));
                              } catch (e) {
                                console.warn(e);
                              }
                            });
                        };
                     
                        const webrtcSendChannel = webrtc.createDataChannel("rtsptowebSendChannel");
                        webrtcSendChannel.onopen = (event) => {
                          console.log(`${webrtcSendChannel.label} has opened`);
                          webrtcSendChannel.send("ping");
                        };
                        webrtcSendChannel.onclose = (_event) => {
                          console.log(`${webrtcSendChannel.label} has closed`);
                          startPlay(videoEl, url);
                        };
                        webrtcSendChannel.onmessage = (event) => console.log(event.data);
                      }
                     
                      const videoEl = document.querySelector("#webrtc2-video");
                      const webrtcUrl = document.querySelector("#webrtc2-url").value;
                     
                      startPlay(videoEl, webrtcUrl);
                    }, 1000);
                    
                    wendy2702 1 Reply Last reply Reply Quote 1
                    • wendy2702
                      wendy2702 @tombox last edited by

                      @tombox So ähnlich habe ich das auch gerade hinbekommen.

                      Jetzt bisschen Off Topic aber kann man eigentlich jedem Widget einzeln unterschiedliche Skripte anhängen?

                      Ich habe das ja gerade für das erste Widget eingefügt und es ist dann ja auch direkt bei allen anderen sichtbar.

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        tombox @wendy2702 last edited by

                        @wendy2702 Kenne mich da auch nicht so aus aber anscheinend.
                        Kannst du was zu der performance von rtsp2web sagen?

                        wendy2702 1 Reply Last reply Reply Quote 0
                        • wendy2702
                          wendy2702 @tombox last edited by

                          @tombox Bin gerade dabei VIS von Motioneye auf RTSP2WEB zu stellen. Dann mal auf Bewegung warten oder morgen selber generieren.

                          Fakt ist das die Prozessor Last im Vergleich zu Motioneye nichts ist.

                          R 1 Reply Last reply Reply Quote 0
                          • T
                            tombox @Marc_el_K last edited by

                            @marc_el_k Anscheinend ist da was falsch in der Kamera umgesetzt. Du hast den default port von 80 auf was anderes geändert und das wird in der snapshot url korrekt angezeigt.

                            1 Reply Last reply Reply Quote 0
                            • M
                              meerkat last edited by

                              Moin.
                              Wozu benötige ich das Script aus dem ersten Post?
                              Dachte es würde reichen das über die url http://127.0.0.1:8083/stream/{STREAM_ID}/channel/{CHANNEL_ID}/webrtc einzubinden.
                              Gruß

                              wendy2702 1 Reply Last reply Reply Quote 0
                              • wendy2702
                                wendy2702 @meerkat last edited by

                                @meerkat Damit der Stream auch gestartet wird.

                                M 1 Reply Last reply Reply Quote 0
                                • M
                                  meerkat @wendy2702 last edited by

                                  @wendy2702 ok, danke

                                  1 Reply Last reply Reply Quote 0
                                  • R
                                    Rookie50 @wendy2702 last edited by Rookie50

                                    @wendy2702 Ich habe eine kurze Frage zum Player. Ich würde den gerne auf mehreren Views benutzen. Aber dazu muss der Player oder der Stream neu geladen werden. Wenn ich den View wechsel sieht es so aus:
                                    3258ce68-5113-4d47-88b9-e1f860066e5a-grafik.png
                                    Gibt es dazu eine Möglichkeit? Oder muss ich für jeden View ein seperates Widget und Script erstellen?

                                    T wendy2702 2 Replies Last reply Reply Quote 0
                                    • T
                                      tombox @Rookie50 last edited by

                                      @rookie50 Muss man nicht für jeden view immer neue widgets anlegen. Ich denke das jeder view ein eignes widgets mit eignen Ids braucht

                                      R 1 Reply Last reply Reply Quote 0
                                      • R
                                        Rookie50 @tombox last edited by Rookie50

                                        @tombox said in Test Adapter onvif camera v1.0.0:

                                        jeden view immer neue widgets anlegen.

                                        Nein, man kann ein Widget auf mehreren Views nutzen. Ich benutzte diese Funktion für ein paar Stati, die ich in mehreren View sehen möchte. Die bekommen dann in den verschiedenen Views einen Namen mit angehangenem "_<VIEWNAME>"
                                        Ok, genau betrachtet sind das dann eigene Widgets 😉
                                        Aber, dass Script funktioniert bei mir im VIS nur auf dem View, den ich beim ersten Start lade. In anderen Views, auch wenn es das einzige Widget im Projekt ist, wo die Kamera zu sehen sein soll, startet der Player das Video nicht.
                                        Das verhält sich ähnlich wie das OpenStreetMap Widget.

                                        EDIT: Nachdem ich nun nochmal nach OpenStreetMap geschaut habe und "Immer rendern" ausgeschaltet habe, muss ich nicht immer erst den View mit den Karten laden. Schon mal wieder ein Fortschritt 😉 .
                                        Und nun habe ich (eher per Zufall) herausgefunden, dass man ein Dialog Widget auch in anderen Views aufrufen kann. Somit funktioniert auch nun die Darstellung der Kamera im HTML Dialog bei PIR Bewegungserkennung.

                                        Danke übriges für den Tip mit rtsp2web, endlich ein Kamerastream im VIS ohne viel CPU Leistung. Bei der Synology 220+ ca. 4 % pro Kamera. Motioneye hat deutlich mehr benötigt. Und zudem auch kaum noch Latenz (ca. 0,5 -1 sek.). 👍 👍

                                        T 1 Reply Last reply Reply Quote 0
                                        • T
                                          tombox @Rookie50 last edited by

                                          @rookie50 Vielleicht kannst du ein paar screenshots posten wie du renderst oder den dialog öffnest

                                          R 1 Reply Last reply Reply Quote 0
                                          • R
                                            Rookie50 @tombox last edited by Rookie50

                                            @tombox Im VIS Editor unter Menupunkt Tools ist die Option Immer rendern:

                                            37e68385-d60b-495f-b443-09fe53242663-grafik.png

                                            Das habe ich ausgeschaltet.

                                            Im VIS benutzte ich HTML-Dialog. Als Icon ist deine ONVIF Snapshot Funktion und im Dialog die HTML Tags für die Kamera. Hier mein Export des Widgets:

                                            [{"tpl":"tplJquiDialog","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html":"<img src=\"http://192.168.101.240:8095/192_168_102_20_80\" width=\"100%\" height=\"100%\">","html_dialog":"<input type=\"hidden\" name=\"webrtc-url\" id=\"webrtc-url\" value=\"http://192.168.101.4:8083/stream/d4548b06-a995-4f5c-a9d3-100a383843d3/channel/0/webrtc\" /> \n<video id=\"webrtc-video\" autoplay muted playsinline controls style=\"max-width: 100%; max-height: 100%;\"></video>","dialog_width":"1280","dialog_height":"800","autoclose":"10000","noHeader":true,"setId":"javascript.0.Cam-Motion.Eingang.Bewegung","setValue":"true","closeOnClick":false,"preload":true,"persistent":true,"title":"Eingang","modal":false,"overflowX":"","overflowY":"","dialog_top":"","dialog_left":"","views":["EG"]},"style":{"left":"1010px","top":"629px","width":"265px","height":"150px","border-width":"1px","border-style":"solid","border-color":"grey","border-radius":""},"widgetSet":"jqui"}]
                                            

                                            Wenn nun der PIR der Kamera eine Bewegung meldet schaltet dieses Script den Dialog des Widgets:

                                            on({id: [].concat(['onvif.0.192_168_102_20_80.events.Device/Trigger/DigitalInput']), val: true}, async function (obj) {
                                              let value = obj.state.val;
                                              let oldValue = obj.oldState.val;
                                              if ((obj.state ? obj.state.val : "") == true && getState("javascript.0.Schalter.Nachtruhe").val == false) {
                                              // Tablet aufwecken
                                                setState("mqtt.1.wallpanel.tab01.command"/*wallpanel/tab01/command*/, '{"wake": true}');
                                              // Dialog öffnen
                                                setState("vis.0.control.command"/*Command for vis*/, '{"instance": "FFFFFFFF", "data": "w00349_OG", "command": "dialogOpen"}');
                                                // CamView fuer 2 Minuten einschalten
                                                    setStateDelayed("vis.0.control.command"/*Command for vis*/, '{"instance": "FFFFFFFF", "data": "w00349_OG", "command": "dialogClose"}', 120000, false);
                                                // command value löschen
                                                setStateDelayed("mqtt.1.wallpanel.tab01.command"/*wallpanel/tab01/command*/, '', 125000, false);
                                                setStateDelayed("javascript.0.Cam-Motion.Eingang.Bewegung"/*Cam-Motion.Eingang.Bewegung*/, false, 120000, false);
                                              }
                                            });
                                            

                                            Kurze Erklärung:
                                            "instance": "FFFFFFFF" -> alles verbundenen VIS Instanzen
                                            "data": "w00349_OG" -> Das Dialog Widget heißt bei mir "w00349_OG"
                                            "command": "dialogXXXXX" -> Open/Close Öffnet/Schließt das Dialog Fenster.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            832
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            48
                                            339
                                            50915
                                            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