AVBlocks for C++  1.19
Audio and Video Software Development Kit
MediaSample Class Referenceabstract

MediaSample represents one or more samples of audio or video data. More...

Inheritance diagram for MediaSample:
Reference

Public Member Functions

virtual MediaBufferbuffer ()=0
 Returns the buffer associated with this sample. More...
 
virtual double endTime () const =0
 Returns the end time of the media sample. More...
 
virtual int32_t flags () const =0
 Returns the media sample flags. More...
 
virtual PictureType::Enum pictureType () const =0
 Returns the picture type (I/P/B/etc.) of a demuxed, decoded or encoded frame. More...
 
virtual void reset ()=0
 Resets the sample to its default values and clears the data in the buffer.
 
virtual void setBuffer (MediaBuffer *buffer)=0
 Sets a new MediaBuffer object. More...
 
virtual void setEndTime (double time)=0
 Sets the end time of the media sample. More...
 
virtual void setFlags (int32_t flags)=0
 Sets the media sample flags. More...
 
virtual void setPictureType (PictureType::Enum pictureType)=0
 Sets the required picture type (I/P/B/etc.). More...
 
virtual void setStartTime (double time)=0
 Sets presentation timestamp (PTS) of the media sample. More...
 
virtual void setStreamNumber (int32_t streamNumber)=0
 Sets the elementary stream to which the sample belongs. More...
 
virtual double startTime () const =0
 Returns the presentation timestamp (PTS) of the media sample. More...
 
virtual int32_t streamNumber () const =0
 Returns the elementary stream to which the sample belongs. More...
 
- Public Member Functions inherited from Reference
virtual int32_t release () const =0
 Releases the instance. More...
 
virtual int32_t retain () const =0
 Retains the instance. More...
 
virtual int32_t retainCount () const =0
 Returns the current reference count. More...
 

Protected Member Functions

 ~MediaSample ()
 This object can be destroyed only by its implementation. More...
 

Detailed Description

MediaSample represents one or more samples of audio or video data.

It is used for storing uncompressed or compressed data.

Constructor & Destructor Documentation

~MediaSample ( )
protected

This object can be destroyed only by its implementation.

The caller must use Reference::release.

See Also
Object Management

Member Function Documentation

virtual MediaBuffer* buffer ( )
pure virtual

Returns the buffer associated with this sample.

Returns
A pointer to a MediaBuffer object. Can be NULL.
virtual double endTime ( ) const
pure virtual

Returns the end time of the media sample.

Returns
The time when the sample should end. Time in seconds.
Remarks
The end time is optional and is valid only if it is greater than the start time.
virtual int32_t flags ( ) const
pure virtual

Returns the media sample flags.

Returns
A combination of flags defined in MediaSampleFlags::Enum.
virtual PictureType::Enum pictureType ( ) const
pure virtual

Returns the picture type (I/P/B/etc.) of a demuxed, decoded or encoded frame.

Returns
A constant from the PictureType::Enum.
Note
Currently this is returned only by the MPEG-2 encoder.
virtual void setBuffer ( MediaBuffer buffer)
pure virtual

Sets a new MediaBuffer object.

The old MediaBuffer object is released. The new one is retained.

Parameters
bufferA pointer to the new MediaBuffer object. Can be NULL.
virtual void setEndTime ( double  time)
pure virtual

Sets the end time of the media sample.

Parameters
time[in] The time when the sample should end. Time is in seconds.
Remarks
The end time is optional and is valid only if it is greater than the start time.
virtual void setFlags ( int32_t  flags)
pure virtual

Sets the media sample flags.

Parameters
flags[in] A combination of flags defined in MediaSampleFlags::Enum.
virtual void setPictureType ( PictureType::Enum  pictureType)
pure virtual

Sets the required picture type (I/P/B/etc.).

Parameters
pictureType[in] A constant from the PictureType::Enum.
Note
Currently this is ignored by encoders.
virtual void setStartTime ( double  time)
pure virtual

Sets presentation timestamp (PTS) of the media sample.

Parameters
timein seconds
virtual void setStreamNumber ( int32_t  streamNumber)
pure virtual

Sets the elementary stream to which the sample belongs.

Parameters
streamNumber[in] A zero-based index of the elementary stream in the container.
virtual double startTime ( ) const
pure virtual

Returns the presentation timestamp (PTS) of the media sample.

Returns
time in seconds
virtual int32_t streamNumber ( ) const
pure virtual

Returns the elementary stream to which the sample belongs.

Returns
A zero-based index of the elementary stream in the container.