mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-23 10:11:08 +00:00
codecparsers: h264parse: improve documentation commentary
https://bugzilla.gnome.org/show_bug.cgi?id=775306
This commit is contained in:
parent
0e8567a981
commit
03615a772a
1 changed files with 31 additions and 26 deletions
|
@ -32,19 +32,20 @@
|
||||||
* @short_description: Convenience library for h264 video
|
* @short_description: Convenience library for h264 video
|
||||||
* bitstream parsing.
|
* bitstream parsing.
|
||||||
*
|
*
|
||||||
* It offers you bitstream parsing in AVC mode or not. To identify Nals in a bitstream and
|
* It offers bitstream parsing in both AVC (length-prefixed) and Annex B
|
||||||
* parse its headers, you should call:
|
* (0x000001 start code prefix) format. To identify a NAL unit in a bitstream
|
||||||
|
* and parse its headers, first call:
|
||||||
* <itemizedlist>
|
* <itemizedlist>
|
||||||
* <listitem>
|
* <listitem>
|
||||||
* #gst_h264_parser_identify_nalu to identify the following nalu in not AVC bitstreams
|
* #gst_h264_parser_identify_nalu to identify a NAL unit in an Annex B type bitstream
|
||||||
* </listitem>
|
* </listitem>
|
||||||
* <listitem>
|
* <listitem>
|
||||||
* #gst_h264_parser_identify_nalu_avc to identify the nalu in AVC bitstreams
|
* #gst_h264_parser_identify_nalu_avc to identify a NAL unit in an AVC type bitstream
|
||||||
* </listitem>
|
* </listitem>
|
||||||
* </itemizedlist>
|
* </itemizedlist>
|
||||||
*
|
*
|
||||||
* Then, depending on the #GstH264NalUnitType of the newly parsed #GstH264NalUnit, you should
|
* The following functions are then available for parsing the structure of the
|
||||||
* call the differents functions to parse the structure:
|
* #GstH264NalUnit, depending on the #GstH264NalUnitType:
|
||||||
* <itemizedlist>
|
* <itemizedlist>
|
||||||
* <listitem>
|
* <listitem>
|
||||||
* From #GST_H264_NAL_SLICE to #GST_H264_NAL_SLICE_IDR: #gst_h264_parser_parse_slice_hdr
|
* From #GST_H264_NAL_SLICE to #GST_H264_NAL_SLICE_IDR: #gst_h264_parser_parse_slice_hdr
|
||||||
|
@ -63,12 +64,14 @@
|
||||||
* </listitem>
|
* </listitem>
|
||||||
* </itemizedlist>
|
* </itemizedlist>
|
||||||
*
|
*
|
||||||
* Note: You should always call gst_h264_parser_parse_nal if you don't actually need
|
* One of these functions *must* be called on every NAL unit in the bitstream,
|
||||||
* #GstH264NalUnitType to be parsed for your personnal use, in order to guarantee that the
|
* in order to keep the internal structures of the #GstH264NalParser up to
|
||||||
* #GstH264NalParser is always up to date.
|
* date. It is legal to call #gst_h264_parser_parse_nal on NAL units of any
|
||||||
|
* type, if no special parsing of the current NAL unit is required by the
|
||||||
|
* application.
|
||||||
*
|
*
|
||||||
* For more details about the structures, look at the ITU-T H.264 and ISO/IEC 14496-10 – MPEG-4
|
* For more details about the structures, look at the ITU-T H.264 and ISO/IEC 14496-10 – MPEG-4
|
||||||
* Part 10 specifications, you can download them from:
|
* Part 10 specifications, available at:
|
||||||
*
|
*
|
||||||
* <itemizedlist>
|
* <itemizedlist>
|
||||||
* <listitem>
|
* <listitem>
|
||||||
|
@ -1333,12 +1336,13 @@ gst_h264_parser_identify_nalu_unchecked (GstH264NalParser * nalparser,
|
||||||
/**
|
/**
|
||||||
* gst_h264_parser_identify_nalu:
|
* gst_h264_parser_identify_nalu:
|
||||||
* @nalparser: a #GstH264NalParser
|
* @nalparser: a #GstH264NalParser
|
||||||
* @data: The data to parse
|
* @data: The data to parse, containing an Annex B coded NAL unit
|
||||||
* @offset: the offset from which to parse @data
|
* @offset: the offset in @data from which to parse the NAL unit
|
||||||
* @size: the size of @data
|
* @size: the size of @data
|
||||||
* @nalu: The #GstH264NalUnit where to store parsed nal headers
|
* @nalu: The #GstH264NalUnit to store the identified NAL unit in
|
||||||
*
|
*
|
||||||
* Parses @data and fills @nalu from the next nalu data from @data
|
* Parses the headers of an Annex B coded NAL unit from @data and puts the
|
||||||
|
* result into @nalu.
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
@ -1383,13 +1387,14 @@ beach:
|
||||||
/**
|
/**
|
||||||
* gst_h264_parser_identify_nalu_avc:
|
* gst_h264_parser_identify_nalu_avc:
|
||||||
* @nalparser: a #GstH264NalParser
|
* @nalparser: a #GstH264NalParser
|
||||||
* @data: The data to parse, must be the beging of the Nal unit
|
* @data: The data to parse, containing an AVC coded NAL unit
|
||||||
* @offset: the offset from which to parse @data
|
* @offset: the offset in @data from which to parse the NAL unit
|
||||||
* @size: the size of @data
|
* @size: the size of @data
|
||||||
* @nal_length_size: the size in bytes of the AVC nal length prefix.
|
* @nal_length_size: the size in bytes of the AVC nal length prefix.
|
||||||
* @nalu: The #GstH264NalUnit where to store parsed nal headers
|
* @nalu: The #GstH264NalUnit to store the identified NAL unit in
|
||||||
*
|
*
|
||||||
* Parses @data and sets @nalu.
|
* Parses the headers of an AVC coded NAL unit from @data and puts the result
|
||||||
|
* into @nalu.
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
@ -1470,7 +1475,7 @@ gst_h264_parser_parse_nal (GstH264NalParser * nalparser, GstH264NalUnit * nalu)
|
||||||
* @sps: The #GstH264SPS to fill.
|
* @sps: The #GstH264SPS to fill.
|
||||||
* @parse_vui_params: Whether to parse the vui_params or not
|
* @parse_vui_params: Whether to parse the vui_params or not
|
||||||
*
|
*
|
||||||
* Parses @data, and fills the @sps structure.
|
* Parses @nalu containing a Sequence Parameter Set, and fills @sps.
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
@ -2009,11 +2014,10 @@ error:
|
||||||
* @nalu: The #GST_H264_NAL_PPS #GstH264NalUnit to parse
|
* @nalu: The #GST_H264_NAL_PPS #GstH264NalUnit to parse
|
||||||
* @pps: The #GstH264PPS to fill.
|
* @pps: The #GstH264PPS to fill.
|
||||||
*
|
*
|
||||||
* Parses @data, and fills the @pps structure.
|
* Parses @nalu containing a Picture Parameter Set, and fills @pps.
|
||||||
*
|
*
|
||||||
* The resulting @pps data structure shall be deallocated with the
|
* The resulting @pps data structure must be deallocated by the caller using
|
||||||
* gst_h264_pps_clear() function when it is no longer needed, or prior
|
* gst_h264_pps_clear().
|
||||||
* to parsing a new PPS NAL unit.
|
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
@ -2054,12 +2058,12 @@ gst_h264_pps_clear (GstH264PPS * pps)
|
||||||
/**
|
/**
|
||||||
* gst_h264_parser_parse_slice_hdr:
|
* gst_h264_parser_parse_slice_hdr:
|
||||||
* @nalparser: a #GstH264NalParser
|
* @nalparser: a #GstH264NalParser
|
||||||
* @nalu: The #GST_H264_NAL_SLICE #GstH264NalUnit to parse
|
* @nalu: The #GST_H264_NAL_SLICE to #GST_H264_NAL_SLICE_IDR #GstH264NalUnit to parse
|
||||||
* @slice: The #GstH264SliceHdr to fill.
|
* @slice: The #GstH264SliceHdr to fill.
|
||||||
* @parse_pred_weight_table: Whether to parse the pred_weight_table or not
|
* @parse_pred_weight_table: Whether to parse the pred_weight_table or not
|
||||||
* @parse_dec_ref_pic_marking: Whether to parse the dec_ref_pic_marking or not
|
* @parse_dec_ref_pic_marking: Whether to parse the dec_ref_pic_marking or not
|
||||||
*
|
*
|
||||||
* Parses @data, and fills the @slice structure.
|
* Parses @nalu containing a coded slice, and fills @slice.
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
@ -2286,7 +2290,8 @@ gst_h264_sps_clear (GstH264SPS * sps)
|
||||||
* @nalu: The #GST_H264_NAL_SEI #GstH264NalUnit to parse
|
* @nalu: The #GST_H264_NAL_SEI #GstH264NalUnit to parse
|
||||||
* @messages: The GArray of #GstH264SEIMessage to fill. The caller must free it when done.
|
* @messages: The GArray of #GstH264SEIMessage to fill. The caller must free it when done.
|
||||||
*
|
*
|
||||||
* Parses @data, create and fills the @messages array.
|
* Parses @nalu containing one or more Supplementary Enhancement Information messages,
|
||||||
|
* and allocates and fills the @messages array.
|
||||||
*
|
*
|
||||||
* Returns: a #GstH264ParserResult
|
* Returns: a #GstH264ParserResult
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue