GStreamer 1.0 Core Reference Manual | ||||
---|---|---|---|---|
Top | Description | Object Hierarchy |
#include <gst/gst.h> GstValueArray; struct GstControlSource; struct GstControlSourceClass; gboolean (*GstControlSourceGetValue) (GstControlSource *self
,GstClockTime timestamp
,gdouble *value
); gboolean (*GstControlSourceGetValueArray) (GstControlSource *self
,GstClockTime timestamp
,GstClockTime interval
,guint n_values
,gdouble *values
); struct GstTimedValue; gboolean gst_control_source_get_value (GstControlSource *self
,GstClockTime timestamp
,gdouble *value
); gboolean gst_control_source_get_value_array (GstControlSource *self
,GstClockTime timestamp
,GstClockTime interval
,guint n_values
,gdouble *values
);
The GstControlSource is a base class for control value sources that could be used by GstController to get timestamp-value pairs. A control source essentially is a function over time, returning gloat values between 0.0 and 1.0.
A GstControlSource is used by first getting an instance of a specific control-source, creating a binding for the control-source to the target property of the element and then adding the binding to the element. The binding will convert the data types and value range to fit to the bound property.
For implementing a new GstControlSource one has to implement
GstControlSourceGetValue and GstControlSourceGetValueArray functions.
These are then used by gst_control_source_get_value()
and
gst_control_source_get_value_array()
to get values for specific timestamps.
struct GstControlSource { GstControlSourceGetValue get_value; /* Returns the value for a property at a given timestamp */ GstControlSourceGetValueArray get_value_array; /* Returns values for a property in a given timespan */ };
The instance structure of GstControlSource.
GstControlSourceGetValue |
Function for returning a value for a given timestamp |
GstControlSourceGetValueArray |
Function for returning a GstValueArray for a given timestamp |
struct GstControlSourceClass { GstObjectClass parent_class; };
The class structure of GstControlSource.
GstObjectClass |
Parent class |
gboolean (*GstControlSourceGetValue) (GstControlSource *self
,GstClockTime timestamp
,gdouble *value
);
Function for returning a value for a given timestamp.
|
the GstControlSource instance |
|
timestamp for which a value should be calculated |
|
a GValue which will be set to the result. It must be initialized to the correct type. |
Returns : |
TRUE if the value was successfully calculated. |
gboolean (*GstControlSourceGetValueArray) (GstControlSource *self
,GstClockTime timestamp
,GstClockTime interval
,guint n_values
,gdouble *values
);
Function for returning an array of values for starting at a given timestamp.
|
the GstControlSource instance |
|
timestamp for which a value should be calculated |
|
the time spacing between subsequent values |
|
the number of values |
|
array to put control-values in |
Returns : |
TRUE if the values were successfully calculated. |
struct GstTimedValue { GstClockTime timestamp; gdouble value; };
Structure for saving a timestamp and a value.
GstClockTime |
timestamp of the value change |
gdouble |
the corresponding value |
gboolean gst_control_source_get_value (GstControlSource *self
,GstClockTime timestamp
,gdouble *value
);
Gets the value for this GstControlSource at a given timestamp.
|
the GstControlSource object |
|
the time for which the value should be returned |
|
the value |
Returns : |
FALSE if the value couldn't be returned, TRUE otherwise. |
gboolean gst_control_source_get_value_array (GstControlSource *self
,GstClockTime timestamp
,GstClockTime interval
,guint n_values
,gdouble *values
);
Gets an array of values for for this GstControlSource. Values that are undefined contain NANs.
|
the GstControlSource object |
|
the first timestamp |
|
the time steps |
|
the number of values to fetch |
|
array to put control-values in |
Returns : |
TRUE if the given array could be filled, FALSE otherwise |