GESBaseEffect
A GESBaseEffect is some operation that applies an effect to the data it receives.
Time Effects
Some operations will change the timing of the stream data they receive in some way. In particular, the GstElement that they wrap could alter the times of the segment they receive in a GST_EVENT_SEGMENT event, or the times of a seek they receive in a GST_EVENT_SEEK event. Such operations would be considered time effects since they translate the times they receive on their source to different times at their sink, and vis versa. This introduces two sets of time coordinates for the event: (internal) sink coordinates and (internal) source coordinates, where segment times are translated from the sink coordinates to the source coordinates, and seek times are translated from the source coordinates to the sink coordinates.
If you use such an effect in GES, you will need to inform GES of the properties that control the timing with ges_base_effect_register_time_property, and the effect's timing behaviour using ges_base_effect_set_time_translation_funcs.
Note that a time effect should not have its has-internal-source set to TRUE.
In addition, note that GES only fully supports time effects whose mapping from the source to sink coordinates (those applied to seeks) obeys:
- Maps the time
0
to0
. So initial time-shifting effects are excluded. - Is monotonically increasing. So reversing effects, and effects that jump backwards in the stream are excluded.
- Can handle a reasonable GstClockTime, relative to the project. So this would exclude a time effect with an extremely large speed-up that would cause the converted GstClockTime seeks to overflow.
- Is 'continuously reversible'. This essentially means that for every time in the sink coordinates, we can, to 'good enough' accuracy, calculate the corresponding time in the source coordinates. Moreover, this should correspond to how segment times are translated from sink to source.
- Only depends on the registered time properties, rather than the state of the GstElement or the data it receives. This would exclude, say, an effect that would speedup if there is more red in the image it receives.
Note that a constant-rate-change effect that is not extremely fast or slow would satisfy these conditions. For such effects, you may wish to use ges_effect_class_register_rate_property.
GESBaseEffect
GObject ╰──GInitiallyUnowned ╰──GESTimelineElement ╰──GESTrackElement ╰──GESOperation ╰──GESBaseEffect ╰──GESEffect
Class structure
GESBaseEffectClass
GES.BaseEffectClass
GES.BaseEffectClass
GES.BaseEffect
GObject.Object ╰──GObject.InitiallyUnowned ╰──GES.TimelineElement ╰──GES.TrackElement ╰──GES.Operation ╰──GES.BaseEffect ╰──GES.Effect
GES.BaseEffect
GObject.Object ╰──GObject.InitiallyUnowned ╰──GES.TimelineElement ╰──GES.TrackElement ╰──GES.Operation ╰──GES.BaseEffect ╰──GES.Effect
Methods
ges_base_effect_is_time_effect
gboolean ges_base_effect_is_time_effect (GESBaseEffect * effect)
Get whether the effect is considered a time effect or not. An effect with registered time properties or set translation functions is considered a time effect.
Parameters:
effect
–
TRUE if effect is considered a time effect.
Since : 1.18
GES.BaseEffect.prototype.is_time_effect
function GES.BaseEffect.prototype.is_time_effect(): {
// javascript wrapper for 'ges_base_effect_is_time_effect'
}
Get whether the effect is considered a time effect or not. An effect with registered time properties or set translation functions is considered a time effect.
Parameters:
Since : 1.18
GES.BaseEffect.is_time_effect
def GES.BaseEffect.is_time_effect (self):
#python wrapper for 'ges_base_effect_is_time_effect'
Get whether the effect is considered a time effect or not. An effect with registered time properties or set translation functions is considered a time effect.
Parameters:
Since : 1.18
ges_base_effect_register_time_property
gboolean ges_base_effect_register_time_property (GESBaseEffect * effect, const gchar * child_property_name)
Register a child property of the effect as a property that, when set, can change the timing of its input data. The child property should be specified as in ges_timeline_element_lookup_child.
You should also set the corresponding time translation using ges_base_effect_set_time_translation_funcs.
Note that effect must not be part of a clip, nor can it have has-internal-source set to TRUE.
Parameters:
effect
–
child_property_name
–
The name of the child property to register as a time property
TRUE if the child property was found and newly registered.
Since : 1.18
GES.BaseEffect.prototype.register_time_property
function GES.BaseEffect.prototype.register_time_property(child_property_name: String): {
// javascript wrapper for 'ges_base_effect_register_time_property'
}
Register a child property of the effect as a property that, when set, can change the timing of its input data. The child property should be specified as in GES.TimelineElement.prototype.lookup_child.
You should also set the corresponding time translation using GES.BaseEffect.prototype.set_time_translation_funcs.
Note that effect must not be part of a clip, nor can it have has-internal-source set to true.
Parameters:
The name of the child property to register as a time property
Since : 1.18
GES.BaseEffect.register_time_property
def GES.BaseEffect.register_time_property (self, child_property_name):
#python wrapper for 'ges_base_effect_register_time_property'
Register a child property of the effect as a property that, when set, can change the timing of its input data. The child property should be specified as in GES.TimelineElement.lookup_child.
You should also set the corresponding time translation using GES.BaseEffect.set_time_translation_funcs.
Note that effect must not be part of a clip, nor can it have has_internal_source set to True.
Parameters:
The name of the child property to register as a time property
Since : 1.18
ges_base_effect_set_time_translation_funcs
gboolean ges_base_effect_set_time_translation_funcs (GESBaseEffect * effect, GESBaseEffectTimeTranslationFunc source_to_sink_func, GESBaseEffectTimeTranslationFunc sink_to_source_func, gpointer user_data, GDestroyNotify destroy)
Set the time translation query functions for the time effect. If an effect is a time effect, it will have two sets of coordinates: one at its sink and one at its source. The given functions should be able to translate between these two sets of coordinates. More specifically, source_to_sink_func should *emulate* how the corresponding GstElement would translate the GstSegment time field, and sink_to_source_func should emulate how the corresponding GstElement would translate the seek query start and stop values, as used in gst_element_seek. As such, sink_to_source_func should act as an approximate reverse of source_to_sink_func.
Note, these functions will be passed a table of time properties, as registered in ges_base_effect_register_time_property, and their values. The functions should emulate what the translation would be if the time properties were set to the given values. They should not use the currently set values.
Note that effect must not be part of a clip, nor can it have has-internal-source set to TRUE.
Parameters:
effect
–
source_to_sink_func
(
[nullable][scope notified][closure])
–
The function to use for querying how a time is translated from the source coordinates to the sink coordinates of effect
sink_to_source_func
(
[nullable][scope notified][closure])
–
The function to use for querying how a time is translated from the sink coordinates to the source coordinates of effect
user_data
–
Data to pass to both source_to_sink_func and sink_to_source_func
destroy
(
[destroy user_data][nullable])
–
Method to call to destroy user_data, or NULL
TRUE if the translation functions were set.
Since : 1.18
GES.BaseEffect.prototype.set_time_translation_funcs
function GES.BaseEffect.prototype.set_time_translation_funcs(source_to_sink_func: GES.BaseEffectTimeTranslationFunc, sink_to_source_func: GES.BaseEffectTimeTranslationFunc): {
// javascript wrapper for 'ges_base_effect_set_time_translation_funcs'
}
Set the time translation query functions for the time effect. If an effect is a time effect, it will have two sets of coordinates: one at its sink and one at its source. The given functions should be able to translate between these two sets of coordinates. More specifically, source_to_sink_func should *emulate* how the corresponding Gst.Element would translate the Gst.Segment time field, and sink_to_source_func should emulate how the corresponding Gst.Element would translate the seek query start and stop values, as used in Gst.Element.prototype.seek. As such, sink_to_source_func should act as an approximate reverse of source_to_sink_func.
Note, these functions will be passed a table of time properties, as registered in GES.BaseEffect.prototype.register_time_property, and their values. The functions should emulate what the translation would be if the time properties were set to the given values. They should not use the currently set values.
Note that effect must not be part of a clip, nor can it have has-internal-source set to true.
Parameters:
The function to use for querying how a time is translated from the source coordinates to the sink coordinates of effect
The function to use for querying how a time is translated from the sink coordinates to the source coordinates of effect
Since : 1.18
GES.BaseEffect.set_time_translation_funcs
def GES.BaseEffect.set_time_translation_funcs (self, source_to_sink_func, sink_to_source_func):
#python wrapper for 'ges_base_effect_set_time_translation_funcs'
Set the time translation query functions for the time effect. If an effect is a time effect, it will have two sets of coordinates: one at its sink and one at its source. The given functions should be able to translate between these two sets of coordinates. More specifically, source_to_sink_func should *emulate* how the corresponding Gst.Element would translate the Gst.Segment time field, and sink_to_source_func should emulate how the corresponding Gst.Element would translate the seek query start and stop values, as used in Gst.Element.seek. As such, sink_to_source_func should act as an approximate reverse of source_to_sink_func.
Note, these functions will be passed a table of time properties, as registered in GES.BaseEffect.register_time_property, and their values. The functions should emulate what the translation would be if the time properties were set to the given values. They should not use the currently set values.
Note that effect must not be part of a clip, nor can it have has_internal_source set to True.
Parameters:
The function to use for querying how a time is translated from the source coordinates to the sink coordinates of effect
The function to use for querying how a time is translated from the sink coordinates to the source coordinates of effect
Since : 1.18
Constants
GES_TYPE_BASE_EFFECT
#define GES_TYPE_BASE_EFFECT ges_base_effect_get_type()
Callbacks
GESBaseEffectTimeTranslationFunc
GstClockTime (*GESBaseEffectTimeTranslationFunc) (GESBaseEffect * effect, GstClockTime time, GHashTable * time_property_values, gpointer user_data)
A function for querying how an effect would translate a time if it had the given child property values set. The keys for time_properties will be the same string that was passed to ges_base_effect_register_time_property, the values will be GValue* values of the corresponding child properties. You should always use the values given in time_properties before using the currently set values.
Parameters:
effect
–
The GESBaseEffect that is doing the time translation
time
–
The GstClockTime to translation
time_property_values
(
[element-typegchar*])
–
A table of child property name/value pairs
user_data
–
Data passed to ges_base_effect_set_time_translation_funcs
The translated time.
Since : 1.18
GES.BaseEffectTimeTranslationFunc
function GES.BaseEffectTimeTranslationFunc(effect: GES.BaseEffect, time: Number, time_property_values: GHashTable (not introspectable), user_data: Object): {
// javascript wrapper for 'GESBaseEffectTimeTranslationFunc'
}
A function for querying how an effect would translate a time if it had the given child property values set. The keys for time_properties will be the same string that was passed to GES.BaseEffect.prototype.register_time_property, the values will be GObject.Value* values of the corresponding child properties. You should always use the values given in time_properties before using the currently set values.
Parameters:
The GES.BaseEffect that is doing the time translation
A table of child property name/value pairs
Data passed to GES.BaseEffect.prototype.set_time_translation_funcs
The translated time.
Since : 1.18
GES.BaseEffectTimeTranslationFunc
def GES.BaseEffectTimeTranslationFunc (effect, time, time_property_values, *user_data):
#python wrapper for 'GESBaseEffectTimeTranslationFunc'
A function for querying how an effect would translate a time if it had the given child property values set. The keys for time_properties will be the same string that was passed to GES.BaseEffect.register_time_property, the values will be GObject.Value* values of the corresponding child properties. You should always use the values given in time_properties before using the currently set values.
Parameters:
The GES.BaseEffect that is doing the time translation
A table of child property name/value pairs
Data passed to GES.BaseEffect.set_time_translation_funcs
The translated time.
Since : 1.18
The results of the search are