<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><blockquote type="cite"><div>Ross, would you please look at this MP2TS file for us?<br><br><span class="Apple-tab-span" style="white-space:pre">     </span><a href="http://etr-usa.com/live555/novideo.ts">http://etr-usa.com/live555/novideo.ts</a><br><br>It always streams successfully via RTSP over raw UDP from mediaServer, but shows no video when streamed from testMPEG2TransportStreamer if the sender starts before the receiver.<br><br>This doesn't happen with any other file we have tried so far.  I'm guessing the problem is that some necessary bit of synchronization data appears only at the beginning of the file, so that if the client isn't receiving when it goes by, it never figures out how to decode the video properly.<br></div></blockquote><div><br></div></div>Yes, that appears to be the case.  Because (according to VLC) the video is MPEG-1 or 2 (packed, along with MPEG audio, into a Transport Stream), I suspect that the video contains a MPEG "Video Sequence Header" only at the beginning, so that if a receiver misses getting this, then the MPEG decoder won't be able to render the rest of the data.<div><br></div><div>BTW, you can get the same effect by running</div><div><span class="Apple-tab-span" style="white-space:pre">  tail -c +188001 novideo.ts ></span> novideo-tail.ts</div><div>i.e., to chop off the first 1000 188-byte Transport Packets.  If you do this, you'll find that VLC can't play video from "novideo-tail.ts" either.</div><div><br></div><div>Because the data is Transport Stream data - which we don't demultiplex before streaming - there's nothing we can do in our code to overcome this.  You would need to demultiplex the Transport Stream and then reprocess the MPEG video to include "Video Sequence Headers" periodically, rather than just at the start of the file.</div><br><br><div apple-content-edited="true">
<span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; "><span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; ">Ross Finlayson<br>Live Networks, Inc.<br><a href="http://www.live555.com/">http://www.live555.com/</a></span></span>
</div>
<br></body></html>