GstAudio.AudioEncoder¶
- Subclasses:
- None 
Methods¶
- Inherited:
- Gst.Element (82), Gst.Object (27), GObject.Object (37), Gst.Preset (11) 
- Structs:
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | 
Virtual Methods¶
- Inherited:
- Gst.Element (16), Gst.Object (1), GObject.Object (7), Gst.Preset (8) 
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | 
Properties¶
- Inherited:
| Name | Type | Flags | Short Description | 
|---|---|---|---|
| r/w | Perform clipping and sample flushing upon discontinuity | ||
| r | Apply granule semantics to buffer metadata (implies perfect-timestamp) | ||
| r/w | Favour perfect timestamps over tracking upstream timestamps | ||
| r/w | Consider discontinuity if timestamp jitter/imperfection exceeds tolerance (ns) | 
Signals¶
- Inherited:
Fields¶
- Inherited:
| Name | Type | Access | Description | 
|---|---|---|---|
| element | r | ||
| input_segment | r | ||
| output_segment | r | ||
| sinkpad | r | ||
| srcpad | r | ||
| stream_lock | r | 
Class Details¶
- class GstAudio.AudioEncoder(**kwargs)¶
- Bases:
- Abstract:
- Yes 
- Structure:
 - This base class is for audio encoders turning raw audio samples into encoded audio data. - GstAudio.AudioEncoderand subclass should cooperate as follows.- Configuration
 - Initially, - GstAudio.AudioEncodercalls start when the encoder element is activated, which allows subclass to perform any global setup.
- GstAudio.AudioEncodercalls set_format to inform subclass of the format of input audio data that it is about to receive. Subclass should setup for encoding and configure various base class parameters appropriately, notably those directing desired input data handling. While unlikely, it might be called more than once, if changing input parameters require reconfiguration.
- GstAudio.AudioEncodercalls stop at end of all processing.
 - As of configuration stage, and throughout processing, - GstAudio.AudioEncodermaintains various parameters that provide required context, e.g. describing the format of input audio data. Conversely, subclass can and should configure these context parameters to inform base class of its expectation w.r.t. buffer handling.- Data processing
 - Base class gathers input sample data (as directed by the context’s frame_samples and frame_max) and provides this to subclass’ handle_frame. - If codec processing results in encoded data, subclass should call - GstAudio.AudioEncoder.finish_frame() to have encoded data pushed downstream. Alternatively, it might also call- GstAudio.AudioEncoder.finish_frame() (with a- Nonebuffer and some number of dropped samples) to indicate dropped (non-encoded) samples.
- Just prior to actually pushing a buffer downstream, it is passed to pre_push. 
- During the parsing process - GstAudio.AudioEncoderClasswill handle both srcpad and sinkpad events. Sink events will be passed to subclass if event callback has been provided.
 
 - Shutdown phase
 - GstAudio.AudioEncoderclass calls stop to inform the subclass that data parsing will be stopped.
 - Subclass is responsible for providing pad template caps for source and sink pads. The pads need to be named “sink” and “src”. It also needs to set the fixed caps on srcpad, when the format is ensured. This is typically when base class calls subclass’ set_format function, though it might be delayed until calling gst_audio_encoder_finish_frame. - In summary, above process should have subclass concentrating on codec data processing while leaving other matters to base class, such as most notably timestamp handling. While it may exert more control in this area (see e.g. pre_push), it is very much not recommended. - In particular, base class will either favor tracking upstream timestamps (at the possible expense of jitter) or aim to arrange for a perfect stream of output timestamps, depending on - GstAudio.AudioEncoder- :perfect-timestamp. However, in the latter case, the input may not be so perfect or ideal, which is handled as follows. An input timestamp is compared with the expected timestamp as dictated by input sample stream and if the deviation is less than- GstAudio.AudioEncoder- :tolerance, the deviation is discarded. Otherwise, it is considered a discontuinity and subsequent output timestamp is resynced to the new position after performing configured discontinuity processing. In the non-perfect-timestamp case, an upstream variation exceeding tolerance only leads to marking DISCONT on subsequent outgoing (while timestamps are adjusted to upstream regardless of variation). While DISCONT is also marked in the perfect-timestamp case, this one optionally (see- GstAudio.AudioEncoder- :hard-resync) performs some additional steps, such as clipping of (early) input samples or draining all currently remaining input data, depending on the direction of the discontuinity.- If perfect timestamps are arranged, it is also possible to request baseclass (usually set by subclass) to provide additional buffer metadata (in OFFSET and OFFSET_END) fields according to granule defined semantics currently needed by oggmux. Specifically, OFFSET is set to granulepos (= sample count including buffer) and OFFSET_END to corresponding timestamp (as determined by same sample count and sample rate). - Things that subclass need to take care of: - Provide pad templates 
- Set source pad caps when appropriate 
- Inform base class of buffer processing needs using context’s frame_samples and frame_bytes. 
- Set user-configurable properties to sane defaults for format and implementing codec at hand, e.g. those controlling timestamp behaviour and discontinuity processing. 
- Accept data in handle_frame and provide encoded results to - GstAudio.AudioEncoder.finish_frame().
 - allocate_output_buffer(size)[source]¶
- Parameters:
- size ( - int) – size of the buffer
- Returns:
- allocated buffer 
- Return type:
 - Helper function that allocates a buffer to hold an encoded audio frame for self's current output format. 
 - finish_frame(buffer, samples)[source]¶
- Parameters:
- buffer ( - Gst.Bufferor- None) – encoded data
- samples ( - int) – number of samples (per channel) represented by encoded data
 
- Returns:
- a - Gst.FlowReturnthat should be escalated to caller (of caller)
- Return type:
 - Collects encoded data and pushes encoded data downstream. Source pad caps must be set when this is called. - If samples < 0, then best estimate is all samples provided to encoder (subclass) so far. buf may be - None, in which case next number of samples are considered discarded, e.g. as a result of discontinuous transmission, and a discontinuity is marked.- Note that samples received in - GstAudio.AudioEncoder.do_handle_frame() may be invalidated by a call to this function.
 - get_allocator()[source]¶
- Returns:
- allocator:
- the - Gst.Allocatorused
- params:
- the - Gst.AllocationParamsof allocator
 
- Return type:
- (allocator: - Gst.Allocatoror- None, params:- Gst.AllocationParams)
 - Lets - GstAudio.AudioEncodersub-classes to know the memory allocator used by the base class and its params.- Unref the allocator after use it. 
 - get_audio_info()[source]¶
- Returns:
- a - GstAudio.AudioInfodescribing the input audio format
- Return type:
 
 - get_frame_samples_max()[source]¶
- Returns:
- currently maximum requested samples per frame 
- Return type:
 
 - get_frame_samples_min()[source]¶
- Returns:
- currently minimum requested samples per frame 
- Return type:
 
 - get_latency()[source]¶
- Returns:
- min:
- a pointer to storage to hold minimum latency 
- max:
- a pointer to storage to hold maximum latency 
 
- Return type:
 - Sets the variables pointed to by min and max to the currently configured latency. 
 - get_tolerance()[source]¶
- Returns:
- encoder audio jitter tolerance threshold. - MT safe. 
- Return type:
 - Queries current audio jitter tolerance threshold. 
 - merge_tags(tags, mode)[source]¶
- Parameters:
- tags ( - Gst.TagListor- None) – a- Gst.TagListto merge, or- Noneto unset previously-set tags
- mode ( - Gst.TagMergeMode) – the- Gst.TagMergeModeto use, usually- Gst.TagMergeMode.REPLACE
 
 - Sets the audio encoder tags and how they should be merged with any upstream stream tags. This will override any tags previously-set with - GstAudio.AudioEncoder.merge_tags().- Note that this is provided for convenience, and the subclass is not required to use this and can still do tag handling on its own. - MT safe. 
 - negotiate()[source]¶
- 
Negotiate with downstream elements to currently configured Gst.Caps. UnmarkGst.PadFlags.NEED_RECONFIGUREin any case. But mark it again if negotiate fails.
 - proxy_getcaps(caps, filter)[source]¶
- Parameters:
- Returns:
- a - Gst.Capsowned by caller
- Return type:
 - Returns caps that express caps (or sink template caps if caps == - None) restricted to channel/rate combinations supported by downstream elements (e.g. muxers).
 - set_allocation_caps(allocation_caps)[source]¶
- 
Sets a caps in allocation query which are different from the set pad’s caps. Use this function before calling GstAudio.AudioEncoder.negotiate(). Setting toNonethe allocation query will use the caps from the pad.New in version 1.10. 
 - set_drainable(enabled)[source]¶
- Parameters:
- enabled ( - bool) – new state
 - Configures encoder drain handling. If drainable, subclass might be handed a - Nonebuffer to have it return any leftover encoded data. Otherwise, it is not considered so capable and will only ever be passed real data.- MT safe. 
 - set_frame_max(num)[source]¶
- Parameters:
- num ( - int) – number of frames
 - Sets max number of frames accepted at once (assumed minimally 1). Requires frame_samples_min and frame_samples_max to be the equal. - Note: This value will be reset to 0 every time before - GstAudio.AudioEncoder.do_set_format() is called.
 - set_frame_samples_max(num)[source]¶
- Parameters:
- num ( - int) – number of samples per frame
 - Sets number of samples (per channel) subclass needs to be handed, at most or will be handed all available if 0. - If an exact number of samples is required, - GstAudio.AudioEncoder.set_frame_samples_min() must be called with the same number.- Note: This value will be reset to 0 every time before - GstAudio.AudioEncoder.do_set_format() is called.
 - set_frame_samples_min(num)[source]¶
- Parameters:
- num ( - int) – number of samples per frame
 - Sets number of samples (per channel) subclass needs to be handed, at least or will be handed all available if 0. - If an exact number of samples is required, - GstAudio.AudioEncoder.set_frame_samples_max() must be called with the same number.- Note: This value will be reset to 0 every time before - GstAudio.AudioEncoder.do_set_format() is called.
 - set_hard_min(enabled)[source]¶
- Parameters:
- enabled ( - bool) – new state
 - Configures encoder hard minimum handling. If enabled, subclass will never be handed less samples than it configured, which otherwise might occur near end-of-data handling. Instead, the leftover samples will simply be discarded. - MT safe. 
 - set_headers(headers)[source]¶
- Parameters:
- headers ([ - Gst.Buffer]) – a list of- Gst.Buffercontaining the codec header
 - Set the codec headers to be sent downstream whenever requested. 
 - set_latency(min, max)[source]¶
- 
Sets encoder latency. If the provided values changed from previously provided ones, this will also post a LATENCY message on the bus so the pipeline can reconfigure its global latency. 
 - set_lookahead(num)[source]¶
- Parameters:
- num ( - int) – lookahead
 - Sets encoder lookahead (in units of input rate samples) - Note: This value will be reset to 0 every time before - GstAudio.AudioEncoder.do_set_format() is called.
 - set_mark_granule(enabled)[source]¶
- Parameters:
- enabled ( - bool) – new state
 - Enable or disable encoder granule handling. - MT safe. 
 - set_perfect_timestamp(enabled)[source]¶
- Parameters:
- enabled ( - bool) – new state
 - Enable or disable encoder perfect output timestamp preference. - MT safe. 
 - set_tolerance(tolerance)[source]¶
- Parameters:
- tolerance ( - int) – new tolerance
 - Configures encoder audio jitter tolerance threshold. - MT safe. 
 - do_close() virtual¶
- Return type:
 - Optional. Called when the element changes to - Gst.State.NULL. Allows closing external resources.
 - do_decide_allocation(query) virtual¶
- 
Optional. Setup the allocation parameters for allocating output buffers. The passed in query contains the result of the downstream allocation query. Subclasses should chain up to the parent implementation to invoke the default handler. 
 - do_flush() virtual¶
- Optional. Instructs subclass to clear any codec caches and discard any pending samples and not yet returned encoded data. 
 - do_getcaps(filter) virtual¶
- 
Optional. Allows for a custom sink getcaps implementation (e.g. for multichannel input specification). If not implemented, default returns GstAudio.AudioEncoder.proxy_getcapsapplied to sink template caps.
 - do_handle_frame(buffer) virtual¶
- Parameters:
- buffer ( - Gst.Buffer) –
- Return type:
 - Provides input samples (or - Noneto clear any remaining data) according to directions as configured by the subclass using the API. Input data ref management is performed by base class, subclass should not care or intervene, and input data is only valid until next call to base class, most notably a call to- GstAudio.AudioEncoder.finish_frame().
 - do_negotiate() virtual¶
- 
Negotiate with downstream elements to currently configured Gst.Caps. UnmarkGst.PadFlags.NEED_RECONFIGUREin any case. But mark it again if negotiate fails.
 - do_open() virtual¶
- Return type:
 - Optional. Called when the element changes to - Gst.State.READY. Allows opening external resources.
 - do_pre_push(buffer) virtual¶
- Parameters:
- buffer ( - Gst.Buffer) –
- Return type:
 - Optional. Called just prior to pushing (encoded data) buffer downstream. Subclass has full discretionary access to buffer, and a not OK flow return will abort downstream pushing. 
 - do_propose_allocation(query) virtual¶
- 
Optional. Propose buffer allocation parameters for upstream elements. Subclasses should chain up to the parent implementation to invoke the default handler. 
 - do_set_format(info) virtual¶
- Parameters:
- info ( - GstAudio.AudioInfo) –
- Return type:
 - Notifies subclass of incoming data format. - GstAudio.AudioInfocontains the format according to provided caps.
 - do_sink_event(event) virtual¶
- 
Optional. Event handler on the sink pad. Subclasses should chain up to the parent implementation to invoke the default handler. 
 - do_sink_query(query) virtual¶
- 
Optional. Query handler on the sink pad. This function should return Trueif the query could be performed. Subclasses should chain up to the parent implementation to invoke the default handler.New in version 1.6. 
 - do_src_event(event) virtual¶
- 
Optional. Event handler on the src pad. Subclasses should chain up to the parent implementation to invoke the default handler. 
 - do_src_query(query) virtual¶
- 
Optional. Query handler on the source pad. This function should return Trueif the query could be performed. Subclasses should chain up to the parent implementation to invoke the default handler.New in version 1.6. 
 - do_start() virtual¶
- Return type:
 - Optional. Called when the element starts processing. Allows opening external resources. 
 - do_stop() virtual¶
- Return type:
 - Optional. Called when the element stops processing. Allows closing external resources. 
 - do_transform_meta(outbuf, meta, inbuf) virtual¶
- Parameters:
- outbuf ( - Gst.Buffer) –
- meta ( - Gst.Meta) –
- inbuf ( - Gst.Buffer) –
 
- Return type:
 - Optional. Transform the metadata on the input buffer to the output buffer. By default this method copies all meta without tags and meta with only the “audio” tag. subclasses can implement this method and return - Trueif the metadata is to be copied.- New in version 1.6. 
 
Property Details¶
- GstAudio.AudioEncoder.props.hard_resync¶
- 
Perform clipping and sample flushing upon discontinuity 
- GstAudio.AudioEncoder.props.mark_granule¶
- 
Apply granule semantics to buffer metadata (implies perfect-timestamp) 
- GstAudio.AudioEncoder.props.perfect_timestamp¶
- 
Favour perfect timestamps over tracking upstream timestamps