Top |
#define | GST_VIDEO_CODEC_FRAME_FLAGS() |
#define | GST_VIDEO_CODEC_FRAME_FLAG_IS_SET() |
#define | GST_VIDEO_CODEC_FRAME_FLAG_SET() |
#define | GST_VIDEO_CODEC_FRAME_FLAG_UNSET() |
#define | GST_VIDEO_CODEC_FRAME_IS_DECODE_ONLY() |
#define | GST_VIDEO_CODEC_FRAME_IS_FORCE_KEYFRAME() |
#define | GST_VIDEO_CODEC_FRAME_IS_FORCE_KEYFRAME_HEADERS() |
#define | GST_VIDEO_CODEC_FRAME_IS_SYNC_POINT() |
#define | GST_VIDEO_CODEC_FRAME_SET_DECODE_ONLY() |
#define | GST_VIDEO_CODEC_FRAME_SET_FORCE_KEYFRAME() |
#define | GST_VIDEO_CODEC_FRAME_SET_FORCE_KEYFRAME_HEADERS() |
#define | GST_VIDEO_CODEC_FRAME_SET_SYNC_POINT() |
#define | GST_VIDEO_CODEC_FRAME_UNSET_FORCE_KEYFRAME() |
#define | GST_VIDEO_CODEC_FRAME_UNSET_FORCE_KEYFRAME_HEADERS() |
#define | GST_VIDEO_CODEC_FRAME_UNSET_SYNC_POINT() |
GstVideoCodecFrame * | gst_video_codec_frame_ref () |
void | gst_video_codec_frame_unref () |
void | gst_video_codec_frame_set_user_data () |
gpointer | gst_video_codec_frame_get_user_data () |
GstVideoCodecState * | gst_video_codec_state_ref () |
void | gst_video_codec_state_unref () |
#define GST_VIDEO_CODEC_FRAME_FLAGS(frame) ((frame)->flags)
The entire set of flags for the frame
#define GST_VIDEO_CODEC_FRAME_FLAG_IS_SET(frame,flag) !!(GST_VIDEO_CODEC_FRAME_FLAGS(frame) & (flag))
Checks whether the given flag
is set
#define GST_VIDEO_CODEC_FRAME_FLAG_SET(frame,flag) (GST_VIDEO_CODEC_FRAME_FLAGS(frame) |= (flag))
This macro sets the given bits
#define GST_VIDEO_CODEC_FRAME_FLAG_UNSET(frame,flag) (GST_VIDEO_CODEC_FRAME_FLAGS(frame) &= ~(flag))
This macro usets the given bits.
#define GST_VIDEO_CODEC_FRAME_IS_DECODE_ONLY(frame) (GST_VIDEO_CODEC_FRAME_FLAG_IS_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_DECODE_ONLY))
Tests if the buffer should only be decoded but not sent downstream.
#define GST_VIDEO_CODEC_FRAME_IS_FORCE_KEYFRAME(frame) (GST_VIDEO_CODEC_FRAME_FLAG_IS_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME))
Tests if the frame must be encoded as a keyframe. Applies only to frames provided to encoders. Decoders can safely ignore this field.
#define GST_VIDEO_CODEC_FRAME_IS_FORCE_KEYFRAME_HEADERS(frame) (GST_VIDEO_CODEC_FRAME_FLAG_IS_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME_HEADERS))
Tests if encoder should output stream headers before outputting the resulting encoded buffer for the given frame.
Applies only to frames provided to encoders. Decoders can safely ignore this field.
#define GST_VIDEO_CODEC_FRAME_IS_SYNC_POINT(frame) (GST_VIDEO_CODEC_FRAME_FLAG_IS_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_SYNC_POINT))
Tests if the frame is a synchronization point (like a keyframe).
Decoder implementations can use this to detect keyframes.
#define GST_VIDEO_CODEC_FRAME_SET_DECODE_ONLY(frame) (GST_VIDEO_CODEC_FRAME_FLAG_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_DECODE_ONLY))
Sets the buffer to not be sent downstream.
Decoder implementation can use this if they have frames that are not meant to be displayed.
Encoder implementation can safely ignore this field.
#define GST_VIDEO_CODEC_FRAME_SET_FORCE_KEYFRAME(frame) (GST_VIDEO_CODEC_FRAME_FLAG_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME))
#define GST_VIDEO_CODEC_FRAME_SET_FORCE_KEYFRAME_HEADERS(frame) (GST_VIDEO_CODEC_FRAME_FLAG_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME_HEADERS))
#define GST_VIDEO_CODEC_FRAME_SET_SYNC_POINT(frame) (GST_VIDEO_CODEC_FRAME_FLAG_SET(frame, GST_VIDEO_CODEC_FRAME_FLAG_SYNC_POINT))
Sets the frame to be a synchronization point (like a keyframe).
Encoder implementations should set this accordingly.
Decoder implementing parsing features should set this when they detect such a synchronization point.
#define GST_VIDEO_CODEC_FRAME_UNSET_FORCE_KEYFRAME(frame) (GST_VIDEO_CODEC_FRAME_FLAG_UNSET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME))
#define GST_VIDEO_CODEC_FRAME_UNSET_FORCE_KEYFRAME_HEADERS(frame) (GST_VIDEO_CODEC_FRAME_FLAG_UNSET(frame, GST_VIDEO_CODEC_FRAME_FLAG_FORCE_KEYFRAME_HEADERS))
#define GST_VIDEO_CODEC_FRAME_UNSET_SYNC_POINT(frame) (GST_VIDEO_CODEC_FRAME_FLAG_UNSET(frame, GST_VIDEO_CODEC_FRAME_FLAG_SYNC_POINT))
GstVideoCodecFrame *
gst_video_codec_frame_ref (GstVideoCodecFrame *frame
);
Increases the refcount of the given frame by one.
void
gst_video_codec_frame_unref (GstVideoCodecFrame *frame
);
Decreases the refcount of the frame. If the refcount reaches 0, the frame will be freed.
void gst_video_codec_frame_set_user_data (GstVideoCodecFrame *frame
,gpointer user_data
,GDestroyNotify notify
);
Sets user_data
on the frame and the GDestroyNotify that will be called when
the frame is freed. Allows to attach private data by the subclass to frames.
If a user_data
was previously set, then the previous set notify
will be called
before the user_data
is replaced.
gpointer
gst_video_codec_frame_get_user_data (GstVideoCodecFrame *frame
);
Gets private data set on the frame by the subclass via
gst_video_codec_frame_set_user_data()
previously.
GstVideoCodecState *
gst_video_codec_state_ref (GstVideoCodecState *state
);
Increases the refcount of the given state by one.
void
gst_video_codec_state_unref (GstVideoCodecState *state
);
Decreases the refcount of the state. If the refcount reaches 0, the state will be freed.
struct GstVideoCodecFrame { guint32 system_frame_number; /* ED */ guint32 decode_frame_number; /* ED */ guint32 presentation_frame_number; /* ED */ GstClockTime dts; /* ED */ GstClockTime pts; /* ED */ GstClockTime duration; /* ED */ int distance_from_sync; /* ED */ GstBuffer *input_buffer; /* ED */ GstBuffer *output_buffer; /* ED */ GstClockTime deadline; /* D */ };
A GstVideoCodecFrame represents a video frame both in raw and encoded form.
guint32 |
Unique identifier for the frame. Use this if you need
to get hold of the frame later (like when data is being decoded).
Typical usage in decoders is to set this on the opaque value provided
to the library and get back the frame using |
|
guint32 |
||
guint32 |
||
GstClockTime |
Decoding timestamp |
|
GstClockTime |
Presentation timestamp |
|
GstClockTime |
Duration of the frame |
|
Distance in frames from the last synchronization point. |
||
GstBuffer * |
the input GstBuffer that created this frame. The buffer is owned by the frame and references to the frame instead of the buffer should be kept. |
|
GstBuffer * |
the output GstBuffer. Implementations should set this either
directly, or by using the
|
|
GstClockTime |
Running time when the frame will be used. |
Flags for GstVideoCodecFrame
struct GstVideoCodecState { GstVideoInfo info; GstCaps *caps; GstBuffer *codec_data; GstCaps *allocation_caps; };
Structure representing the state of an incoming or outgoing video stream for encoders and decoders.
Decoders and encoders will receive such a state through their
respective set_format
vmethods.
Decoders and encoders can set the downstream state, by using the
or
gst_video_decoder_set_output_state()
methods.gst_video_encoder_set_output_state()
GstVideoInfo |
The GstVideoInfo describing the stream |
|
GstCaps * |
The GstCaps used in the caps negotiation of the pad. |
|
GstBuffer * |
a GstBuffer corresponding to the 'codec_data' field of a stream, or NULL. |
|
GstCaps * |
The GstCaps for allocation query and pool negotiation. Since: 1.10 |