[Live-devel] fPresentationTime fDurationInMicroseconds value setup

Ross Finlayson finlayson at live555.com
Tue Jan 26 18:08:31 PST 2010


>I need to understand the value of fPresentationTime 
>fDurationInMicroseconds. Those two are used in almost all 
>videoframers.
>I have an IP camera, which sends out video frames in the oder of 
>pps, sps, I, P, P, P...(29 times) in a second.  So should the 
>fPresentationTime/ fDurationInMicroseconds be set as 1000/32 
>(including both pps ,sps and vidoe frames) ms or 1000/30 (only the 
>video frames) ms?

Note that "fPresentationTime" and "fDurationInMicroseconds" are 
separate variables, and both should be set (although, if you know 
that your framer will always be reading from a live source (rather 
than a file), you can probably omit setting 
"fDurationInMicroseconds").

(Note: Because you mention "PPS" and "SPS", I assume that you're 
referring specifically to H.264 video.)

"fDurationInMicroseconds" should be set to 1000000/framerate  for the 
NAL unit that ends a video frame (Note: This will be the NAL unit for 
which your reimplemented "currentNALUnitEndsAccessUnit()" virtual 
function will return True), and should be set to 0 for all other NAL 
units.

Similarly, all NAL units that make up a single video frame (including 
any PPS and SPS NAL units) should be given the same 
"fPresentationTime" value (i.e., the presentation time of the video 
frame).

>It looks the framer put several video frames in a single RTP packet.

No, it's the "H264VideoRTPSink" class (i.e., our implementation of 
the RTP payload format for H.264) that takes care of packing NAL 
units into RTP packets.  You don't need to know or care about this. 
Just feed the "H264VideoRTPSink" one NAL unit at a time.
-- 

Ross Finlayson
Live Networks, Inc.
http://www.live555.com/


More information about the live-devel mailing list