MagicMirror Forum
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • 3rd-Party-Modules
    • Donate
    • Discord
    • Register
    • Login
    A New Chapter for MagicMirror: The Community Takes the Lead
    Read the statement by Michael Teeuw here.

    [MMM-RTSPStream] - Video Streaming from Live Feeds & Security Cameras

    Scheduled Pinned Locked Moved Utilities
    602 Posts 67 Posters 2.1m Views 68 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • N Offline
      Niggich @Drooneyef
      last edited by Niggich

      @Drooneyef I put the port of my cam behind the IP-adress…

      module: 'MMM-RTSPStream',
      position: 'bottom_center',
      config: {
      		autoStart: true,
              rotateStreams: false,
              showSnapWhenPaused: false,
              moduleWidth: 704,
              moduleHeight: 240,
              moduleOffset: { top: 212, left: 0 },
              localPlayer: 'omxplayer',
              	stream1: {
                      name: '',
                      url: 'rtsp://192.168.113.125:554/live/ch1',
                      shutdownDelay: 0,
                      width: 320,
                      height: 240,
                      frameRate: "20",
                      port: 9999,
      			},
      			stream2: {
                      name: '',
                      url: 'rtsp://192.168.113.103:554/live/ch1',
                      shutdownDelay: 0,
                      width: 320,
                      height: 240,
                      frameRate: "20",
                      port: 10000,
      			},
      
      1 Reply Last reply Reply Quote 0
      • N Offline
        Niggich @barnosch
        last edited by

        @barnosch thx this works fine for me…

        1 Reply Last reply Reply Quote 0
        • S Offline
          shbatm Module Developer
          last edited by shbatm

          @barnosch @Niggich - Glad you got it working. I will clarify in the next update: the camera port should be included in the url. The port setting for the stream is actually the socket ffmpeg uses (when ffmpeg is used instead of omx).

          If anyone has any additional feature requests, clarifications, config options they would like, please let me know on here. I will get back to working on this module in the coming weeks; I am Houston, TX based so I’ve been occupied with other matters recently.

          1 Reply Last reply Reply Quote 0
          • N Offline
            Niggich
            last edited by Niggich

            @shbatm - The stream is working. Now I have another question/problem. When I hide the module an show it again the Video picture is in Fullscreen. Any fix for this? thx a lot…

            1 Reply Last reply Reply Quote 0
            • S Offline
              shbatm Module Developer
              last edited by

              @Niggich I will need to investigate further.

              As a temporary fix, you can try deleting Line 107 and Lines 109-114 in the node_helper.js file:

                  ~/MagicMirror/modules/MMM-RTSPStream/node_helper.js
              

              You should be deleting the if…else block and this line will remain:

              args.unshift("--win", `${payload.box.left}, ${payload.box.top}, ${payload.box.right}, ${payload.box.bottom}`);
              

              I do not know if this will fix the problem but it is worth a try. I have opened Issue #13 to track the position, border, and fullscreen resume problems.

              N 1 Reply Last reply Reply Quote 0
              • S Offline
                shbatm Module Developer @barnosch
                last edited by shbatm

                @barnosch said in [MMM-RTSPStream] - Video Streaming from Live Feeds & Security Cameras:

                added the pkill commands but it does not work. It does not kill the apps.
                From time to time, the feed disappears. Have not yet found when and why.
                Sometimes it runs 2 days without problems, the other day it only lasts for some hours.

                Issue #14 opened to track this problem to closure.

                1 Reply Last reply Reply Quote 0
                • N Offline
                  Niggich @shbatm
                  last edited by

                  @shbatm thank you for the fast answer, but this doesn’t fix the problem.

                  S 1 Reply Last reply Reply Quote 0
                  • S Offline
                    shbatm Module Developer @Niggich
                    last edited by shbatm

                    @Niggich could you please post your server log (console or PM2’s log file) when it does this? You should have several lines starting with:

                    Starting stream stream1 with args: 
                    

                    Also, what are you using to show/hide the module? (via MMM-Remote-Control or another module?)

                    This will help diagnose.

                    N 1 Reply Last reply Reply Quote 0
                    • N Offline
                      Niggich @shbatm
                      last edited by Niggich

                      @shbatm To show/hide the modules I using MMM-remote-Control.

                      Here’s the server log.

                      Starting stream stream1 with args: [
                      0|mm       |     "--avdict",
                      0|mm       |     "rtsp_transport:tcp",
                      0|mm       |     "--win",
                      0|mm       |     "203.390625, 1491.390625, 523.390625, 1731.390625",
                      0|mm       |     "--live",
                      0|mm       |     "--video_queue",
                      0|mm       |     "4",
                      0|mm       |     "--fps",
                      0|mm       |     "30",
                      0|mm       |     "rtsp://192.168.113.125:554/live/ch1"
                      0|mm       | ]
                      0|mm       | Starting stream stream2 with args: [
                      0|mm       |     "--avdict",
                      0|mm       |     "rtsp_transport:tcp",
                      0|mm       |     "--win",
                      0|mm       |     "553.390625, 1491.390625, 873.390625, 1731.390625",
                      0|mm       |     "--live",
                      0|mm       |     "--video_queue",
                      0|mm       |     "4",
                      0|mm       |     "--fps",
                      0|mm       |     "30",
                      0|mm       |     "rtsp://192.168.113.103:554/live/ch1"
                      0|mm       | ]
                      
                      
                      1 Reply Last reply Reply Quote 0
                      • K Offline
                        kasperb
                        last edited by

                        Hello,

                        @shbatm thanks for the great module!

                        In order to make my camera work in omxplayer, I need to enter the following command before the RTSP streaming URL in Terminal:

                        omxplayer --avdict rtsp_transport:tcp 
                        

                        The RTSP stream works fine with the added command in omxplayer. Full working command for reference:

                        omxplayer --avdict rtsp_transport:tcp rtsp://admin:admin@192.168.0.130:10554/tcp/av0_1
                        
                        

                        Is there a way to add the command to the config in order for the camera to work?

                        When looking at node helper.js I see the following reference:

                            if (this.config[payload.name].protocol !== "udp") {
                                args.unshift("--avdict", "rtsp_transport:tcp");
                        

                        I’ve tried to switch the protocol in the config to ‘udp’ (as well as ‘tcp’) to no avail. I hope you could point me in the right direction in order to solve this issue.

                        Full config below for reference:

                        
                           {
                                    module: 'MMM-RTSPStream',
                                    position: 'middle_center',
                                    config: {
                                        autoStart: true,
                                        rotateStreams: false,
                                        rotateStreamTimeout: 10,
                                        showSnapWhenPaused: false,
                                        moduleWidth: 354,
                                        moduleHeight: 240,
                                        moduleOffset: 0,
                                        localPlayer: 'omxplayer',    
                                        stream1: {
                                            name: '360 Cam',
                                            url: 'rtsp://admin:admin@192.168.0.130:10554/tcp/av0_1',
                                            protocol: 'udp',
                                            snapshotUrl: '',
                                            snapshotRefresh: 10, // Seconds
                                            frameRate: "5",
                                            port: 9999,
                                        }
                                    }  
                        

                        Thanks in advance!

                        S 1 Reply Last reply Reply Quote 0
                        • S Offline
                          shbatm Module Developer @kasperb
                          last edited by

                          @kasperb said in [MMM-RTSPStream] - Video Streaming from Live Feeds & Security Cameras:

                          Is there a way to add the command to the config in order for the camera to work?

                          Adding protocol: 'tcp' should have done the trick. You can also try just removing the protocol line completely since the default protocol is TCP. The default command for omxplayer is:

                          omxplayer --avdict rtsp_transport:tcp --win 'x y w h' --live --video_queue 4 --fps 30 {{url}}
                          

                          The bit of code you referenced is to not include --avdict rtsp_transport:tcp when using a UDP stream.

                          Also, check the console log to see what command was used to start OMXPlayer. It should print the list of arguments.

                          1 Reply Last reply Reply Quote 0
                          • K Offline
                            kasperb
                            last edited by

                            @shbatm Thanks for clarifying. I’ve removed protocol: 'tcp' from the config.

                            When executing the default command in Terminal, the video displays properly on my screen.

                            The MM logs indicate that the stream is started accordingly as well (see below), but unfortunately still nothing is visible on my Mirror.

                            0|mm       | Starting stream stream1 with args: [
                            0|mm       |     "--avdict rtsp_transport:tcp",
                            0|mm       |     "--win",
                            0|mm       |     "379.5, 841.5, 731.5, 1083.5",
                            0|mm       |     "--live",
                            0|mm       |     "--video_queue",
                            0|mm       |     "4",
                            0|mm       |     "--fps",
                            0|mm       |     "30",
                            0|mm       |     "rtsp://admin:admin@192.168.0.130:10554/tcp/av0_1"
                            0|mm       | ]
                            
                            
                            1 Reply Last reply Reply Quote 0
                            • S Offline
                              shbatm Module Developer
                              last edited by

                              @kasperb - I have a suspicion – I think this is the same issue @Niggich was having where OMXPlayer doesn’t like non-integer window dimensions.

                              Please try changing the moduleOffset: 0, setting to 0.5 and see if the video will work. If it works, you can change the offset back to 0 and try updating the module with the patch I just pushed:

                              cd ~/MagicMirror/modules/MMM-RTSPStream
                              git fetch --all
                              git pull
                              

                              If you experience issues with the stream stopping after running for a few days, I am still finalizing work on another branch to resolve this: wip_patch which runs OMXPlayer through pm2 so it will automatically restart feed and hopefully be more stable.

                              B K 2 Replies Last reply Reply Quote 0
                              • B Offline
                                barnosch @shbatm
                                last edited by

                                @shbatm said in [MMM-RTSPStream] - Video Streaming from Live Feeds & Security Cameras:

                                If you experience issues with the stream stopping after running for a few days, I am still finalizing work on another branch to resolve this: wip_patch which runs OMXPlayer through pm2 so it will automatically restart feed and hopefully be more stable.

                                Great! Looking forward to it.

                                1 Reply Last reply Reply Quote 0
                                • K Offline
                                  kasperb @shbatm
                                  last edited by

                                  @shbatm I’ve tried changing the moduleOffset to 0.5, as well as some other experimental values, but unfortunately that didn’t do the trick.

                                  The configuration itself should work, as I had it working with a different RTSP cam previously.

                                  K 1 Reply Last reply Reply Quote 0
                                  • J Offline
                                    Johans
                                    last edited by

                                    Hi,
                                    Can’t get this up and running.
                                    tried to figure out the problem but as i’m newbie i’m missing the skills to locate the problem.
                                    what I have done so far:
                                    Tested my Foscam stream with VLC. This didn’t worked either. error message:

                                    //Uw invoer kan niet geopend worden:
                                    VLC kon de MRL 'rtsp://garden:garden1000%@192.168.1.241:1052/Videomain' niet openen. Controleer het logboek voor details.
                                    
                                    

                                    then tested VLC with default stream - and this is working fine.
                                    Next installed omxplayer and applied my camera stream as follows.

                                    //sudo omxplayer -o hdmi rtsp://garden:garden1000%@192.168.1.241:1052/videoMain
                                    
                                    Video codec omx-h264 width 1280 height 720 profile 66 fps 8.333333
                                    Audio codec pcm_mulaw channels 1 samplerate 8000 bitspersample 8
                                    Subtitle count: 0, state: off, index: 1, delay: 0
                                    V:PortSettingsChanged: 1280x720@8.33 interlace:0 deinterlace:0 anaglyph:0 par:1.00 display:0 layer:0 alpha:255 aspectMode:0
                                    
                                    
                                    

                                    This works perfect, getting full image on the display.
                                    conclusion: software is OK - just weird that my stream is not working on VLC.
                                    could it because password has special char ‘%’ in it?

                                    as omxplayer seams to work, I went back to config and added omxplayer.
                                    switched to the wip branch.
                                    started mirror - nothing happens - i get a blank screen. - below my config

                                    //{
                                    		            module: 'MMM-RTSPStream',
                                    			    classes: 'default everyone',
                                    		            position: 'middle_center',
                                    		            config: {
                                    		                autoStart: true,
                                    		                rotateStreams: false,
                                    		                rotateStreamTimeout: 10,
                                    		                showSnapWhenPaused: false,
                                    		                moduleWidth: 354,
                                    		                moduleHeight: 240,
                                    				localPlayer: 'omxplayer',
                                    		                stream1: {
                                    		                    name: 'Webcam 1 Test Stream',
                                    		                    url: 'rtsp://garden:garden1000%@192.168.1.241:1052/videoMain',
                                    		                    snapshotUrl: '',
                                    		                    snapshotRefresh: 10, // Seconds
                                    		                    frameRate: "25",
                                    		                    port: 9999,
                                    		                }
                                    		            }
                                          		  },
                                    

                                    without omxplayer and master branch active, I see the video play icon on the mirror, but nothing is displayed.

                                    any ideas help to get this running would be great.

                                    Also installed MMM-IP webcam but also no image from the webcam.

                                    J K 2 Replies Last reply Reply Quote 0
                                    • J Offline
                                      Johans @Johans
                                      last edited by

                                      Switched back to master branch
                                      started in dev mode.
                                      error info see picture
                                      0_1507669789919_Error RTSPStream.png

                                      S 1 Reply Last reply Reply Quote 0
                                      • K Offline
                                        kasperb @kasperb
                                        last edited by

                                        @shbatm I did a fresh install of the module, and am pleased to inform you that it’s working fine now. Thanks for your help!

                                        1 Reply Last reply Reply Quote 0
                                        • K Offline
                                          kasperb @Johans
                                          last edited by

                                          @Johans I had a similar issue, and was able to resolve it by re-installing the module.

                                          I just realized that I also added the cam’s ip to the IP whitelist and moved this module to the top of the config; not sure if that did anything, but mine is working now, so it might be worth a shot.

                                          J 1 Reply Last reply Reply Quote 0
                                          • S Offline
                                            shbatm Module Developer @Johans
                                            last edited by

                                            @Johans Which other modules are you using? It looks like you may be using something like MMM-ProfileSwitcher, there may be a conflict between these modules or it may be because of the % symbol in the password.

                                            Also, when you switched to the wip branch, did you remember to re-run npm install in that folder? There are some additional dependencies for the wip branch.

                                            J 1 Reply Last reply Reply Quote 1

                                            Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                            Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                            With your input, this post could be even better 💗

                                            Register Login
                                            • 1
                                            • 2
                                            • 3
                                            • 4
                                            • 5
                                            • 30
                                            • 31
                                            • 3 / 31
                                            • First post
                                              Last post
                                            Enjoying MagicMirror? Please consider a donation!
                                            MagicMirror created by Michael Teeuw.
                                            Forum managed by Sam, technical setup by Karsten.
                                            This forum is using NodeBB as its core | Contributors
                                            Contact | Privacy Policy