| Top |  |  |  |  | 
| GstMpegvideoParserGstMpegvideoParser — Convenience library for mpeg1 and 2 video bitstream parsing. | 
| enum | GstMpegVideoPacketTypeCode | 
| enum | GstMpegVideoPacketExtensionCode | 
| enum | GstMpegVideoLevel | 
| enum | GstMpegVideoProfile | 
| enum | GstMpegVideoPictureType | 
| enum | GstMpegVideoPictureStructure | 
| struct | GstMpegVideoSequenceHdr | 
| struct | GstMpegVideoSequenceExt | 
| struct | GstMpegVideoPictureHdr | 
| struct | GstMpegVideoGop | 
| struct | GstMpegVideoPictureExt | 
| struct | GstMpegVideoQuantMatrixExt | 
gboolean gst_mpeg_video_parse (GstMpegVideoPacket *packet,const guint8 *data,gsize size,guint offset);
Parses the MPEG 1/2 video bitstream contained in data
, and returns the
offset, and if known also the size, in packet
. This function will scan
the data to find the next packet if needed.
gboolean gst_mpeg_video_parse_sequence_header (GstMpegVideoSequenceHdr *seqhdr,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_sequence_header is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_sequence_header() instead.
Parses the seqhdr
 Mpeg Video Sequence Header structure members from data
| seqhdr | The GstMpegVideoSequenceHdr structure to fill. | [out] | 
| data | The data from which to parse the sequence header | |
| size | The size of  | |
| offset | The offset in byte from which to start parsing  | 
gboolean gst_mpeg_video_parse_picture_header (GstMpegVideoPictureHdr *hdr,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_picture_header is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_picture_header() instead.
Parsers the hdr
 Mpeg Video Picture Header structure members from data
| hdr | The GstMpegVideoPictureHdr structure to fill. | [out] | 
| data | The data from which to parse the picture header | |
| size | The size of  | |
| offset | The offset in byte from which to start the parsing | 
gboolean gst_mpeg_video_parse_picture_extension (GstMpegVideoPictureExt *ext,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_picture_extension is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_picture_extension() instead.
Parse the ext
 Mpeg Video Picture Extension structure members from data
| ext | The GstMpegVideoPictureExt structure to fill. | [out] | 
| data | The data from which to parse the picture extension | |
| size | The size of  | |
| offset | The offset in byte from which to start the parsing | 
gboolean gst_mpeg_video_parse_gop (GstMpegVideoGop *gop,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_gop is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_gop() instead.
Parses the gop
 Mpeg Video Group of Picture structure members from data
| gop | The GstMpegVideoGop structure to fill. | [out] | 
| data | The data from which to parse the gop | |
| size | The size of  | |
| offset | The offset in byte from which to start the parsing | 
gboolean gst_mpeg_video_parse_sequence_extension (GstMpegVideoSequenceExt *seqext,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_sequence_extension is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_sequence_extension() instead.
Parses the seqext
 Mpeg Video Sequence Extension structure members from data
| seqext | The GstMpegVideoSequenceExt structure to fill. | [out] | 
| data | The data from which to parse the sequence extension | |
| size | The size of  | |
| offset | The offset in byte from which to start parsing  | 
gboolean gst_mpeg_video_parse_sequence_display_extension (GstMpegVideoSequenceDisplayExt *seqdisplayext,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_sequence_display_extension is deprecated and should not be used in newly-written code.
gboolean gst_mpeg_video_parse_quant_matrix_extension (GstMpegVideoQuantMatrixExt *quant,const guint8 *data,gsize size,guint offset);
gst_mpeg_video_parse_quant_matrix_extension is deprecated and should not be used in newly-written code.
Use gst_mpeg_video_packet_parse_quant_matrix_extension() instead.
Parses the quant
 Mpeg Video Quant Matrix Extension structure members from
data
| quant | The GstMpegVideoQuantMatrixExt structure to fill. | [out] | 
| data | The data from which to parse the Quantization Matrix extension | |
| size | The size of  | |
| offset | The offset in byte from which to start the parsing | 
gboolean gst_mpeg_video_finalise_mpeg2_sequence_header (GstMpegVideoSequenceHdr *hdr,GstMpegVideoSequenceExt *seqext,GstMpegVideoSequenceDisplayExt *displayext);
void gst_mpeg_video_quant_matrix_get_raster_from_zigzag (guint8 out_quant[64],const guint8 quant[64]);
Converts quantization matrix quant
 from zigzag scan order to
raster scan order and store the resulting factors into out_quant
.
Note: it is an error to pass the same table in both quant
 and
out_quant
 arguments.
Since: 1.2
void gst_mpeg_video_quant_matrix_get_zigzag_from_raster (guint8 out_quant[64],const guint8 quant[64]);
Converts quantization matrix quant
 from raster scan order to
zigzag scan order and store the resulting factors into out_quant
.
Note: it is an error to pass the same table in both quant
 and
out_quant
 arguments.
Since: 1.2
Indicates the type of MPEG packet
Indicates what type of packets are in this block, some are mutually exclusive though - ie, sequence packs are accumulated separately. GOP & Picture may occur together or separately.
Mpeg-2 Profiles.
struct GstMpegVideoSequenceHdr {
  guint16 width, height;
  guint8  aspect_ratio_info;
  guint8  frame_rate_code;
  guint32 bitrate_value;
  guint16 vbv_buffer_size_value;
  guint8  constrained_parameters_flag;
  guint8  load_intra_quantiser_matrix;
  guint8  intra_quantizer_matrix[64];
  guint8  load_non_intra_quantiser_matrix;
  guint8  non_intra_quantizer_matrix[64];
  /* Calculated values */
  guint   par_w, par_h;
  guint   fps_n, fps_d;
  guint   bitrate;
};
The Mpeg2 Video Sequence Header structure.
| guint16  | Width of each frame | |
| guint16  | Height of each frame | |
| guint8  | ||
| guint8  | ||
| guint32  | Value of the bitrate as is in the stream (400bps unit) | |
| guint16  | ||
| guint8  | 
 | |
| guint8  | 
 | |
| guint8  | intra-quantization table, in zigzag scan order | |
| guint8  | 
 | |
| guint8  | non-intra quantization table, in zigzag scan order | |
| guint  | Calculated Pixel Aspect Ratio width | |
| guint  | Calculated Pixel Aspect Ratio height | |
| guint  | Calculated Framrate nominator | |
| guint  | Calculated Framerate denominator | |
| guint  | the real bitrate of the Mpeg video stream in bits per second, 0 if VBR stream | 
struct GstMpegVideoSequenceExt {
  /* mpeg2 decoder profile */
  guint8 profile;
  /* mpeg2 decoder level */
  guint8 level;
  guint8 progressive;
  guint8 chroma_format;
  guint8 horiz_size_ext, vert_size_ext;
  guint16 bitrate_ext;
  guint8 vbv_buffer_size_extension;
  guint8 low_delay;
  guint8 fps_n_ext, fps_d_ext;
  /* Additional information */
  guint8 profile_level_escape_bit;
};
The Mpeg2 Video Sequence Extension structure.
| guint8  | mpeg2 decoder profile | |
| guint8  | mpeg2 decoder level | |
| guint8  | ||
| guint8  | indicates the chrominance format | |
| guint8  | Horizontal size | |
| guint8  | Vertical size | |
| guint16  | The bitrate | |
| guint8  | VBV vuffer size | |
| guint8  | 
 | |
| guint8  | Framerate nominator code | |
| guint8  | Framerate denominator code | |
| guint8  | Escape bit. If set, the meaning of the
 | 
struct GstMpegVideoPictureHdr {
  guint16 tsn;
  guint8 pic_type;
  guint16 vbv_delay;
  guint8 full_pel_forward_vector, full_pel_backward_vector;
  guint8 f_code[2][2];
};
The Mpeg2 Video Picture Header structure.
struct GstMpegVideoGop {
  guint8 drop_frame_flag;
  guint8 hour, minute, second, frame;
  guint8 closed_gop;
  guint8 broken_link;
};
The Mpeg Video Group of Picture structure.
struct GstMpegVideoPictureExt {
  guint8 f_code[2][2];
  guint8 intra_dc_precision;
  guint8 picture_structure;
  guint8 top_field_first;
  guint8 frame_pred_frame_dct;
  guint8 concealment_motion_vectors;
  guint8 q_scale_type;
  guint8 intra_vlc_format;
  guint8 alternate_scan;
  guint8 repeat_first_field;
  guint8 chroma_420_type;
  guint8 progressive_frame;
  guint8 composite_display;
  guint8 v_axis;
  guint8 field_sequence;
  guint8 sub_carrier;
  guint8 burst_amplitude;
  guint8 sub_carrier_phase;
};
The Mpeg2 Video Picture Extension structure.
| guint8  | ||
| guint8  | Intra DC precision | |
| guint8  | Structure of the picture | |
| guint8  | Top field first | |
| guint8  | Frame | |
| guint8  | Concealment Motion Vectors | |
| guint8  | Q Scale Type | |
| guint8  | Intra Vlc Format | |
| guint8  | Alternate Scan | |
| guint8  | Repeat First Field | |
| guint8  | Chroma 420 Type | |
| guint8  | ||
| guint8  | ||
| guint8  | ||
| guint8  | ||
| guint8  | ||
| guint8  | ||
| guint8  | 
struct GstMpegVideoQuantMatrixExt {
 guint8 load_intra_quantiser_matrix;
 guint8 intra_quantiser_matrix[64];
 guint8 load_non_intra_quantiser_matrix;
 guint8 non_intra_quantiser_matrix[64];
 guint8 load_chroma_intra_quantiser_matrix;
 guint8 chroma_intra_quantiser_matrix[64];
 guint8 load_chroma_non_intra_quantiser_matrix;
 guint8 chroma_non_intra_quantiser_matrix[64];
};
The Quant Matrix Extension structure that exposes quantization matrices in zigzag scan order. i.e. the original encoded scan order.