GstCaps Capabilities of pads GstCaps is used to attach capabilities to a pad. Capabilities are made of a mime-type and a set of properties. GstCaps can be named and chained into a list, which is then a GstCaps on its own. GstCaps are created with gst_caps_new(), which takes a name, a mime type and a pointer to a #GstProps. A convenience macro with a cleaner syntax is available to create a caps with GST_CAPS_NEW(). The following example shows how to create a GstCaps. GstCaps *caps; caps = gst_caps_new ( "my_caps", /* capability name */ "audio/raw", /* mime type */ gst_props_new ( /* properties */ "format", GST_PROPS_STRING ("float"), "layout", GST_PROPS_INT (5), NULL)); The following code example is equivalent to the above example: GstCaps *caps; caps = GST_CAPS_NEW ( "my_caps", /* capability name */ "audio/raw", /* mime type */ "format", GST_PROPS_STRING ("float"), "channels", GST_PROPS_INT (5) ); GstCaps are refcounted with gst_caps_ref() and gst_caps_unref(). GstCaps can be chained with the gst_caps_append(), gst_caps_prepend() and gst_caps_chain() functions. Use gst_caps_get_by_name() to get a named caps structure from a chained list. To get the properties of a caps structure the functions gst_caps_get_boolean(), gst_caps_get_fourcc_int(), gst_caps_get_int(), gst_caps_get_string(), gst_caps_get_float(), which all take a property name as an argument. The properties of the caps structure can be modified with gst_caps_set, which takes a list of key value pairs in the #GstProps syntax as shown by this example: GstCaps *caps; .... gst_caps_set (caps, "format", GST_PROPS_STRING ("int"), NULL); gst_caps_set (caps, "channels", GST_PROPS_INT (20), NULL); before modifying a GstCaps, it is a good idea to make a copy if it first with gst_caps_copy_on_write(). This will copy the GstCaps if the refcount is >1. If you need a unique instance of a GstCaps you can use the convenient GST_CAPS_FACTORY() macro as shown below. GST_CAPS_FACTORY (my_caps, GST_CAPS_NEW ( "caps1", "audio/raw", "format", GST_PROPS_STRING ("float"), "channels", GST_PROPS_INT (5) ), GST_CAPS_NEW ( "caps2", "audio/raw", "format", GST_PROPS_STRING ("int"), "channels", GST_PROPS_INT (5) ) ) void some_function (void) { GstCaps *caps = GST_CAPS_GET (my_caps); ... } If you want to check if a connection between source and destination caps is always possible, use gst_caps_is_always_compatible(), which returns a boolean. If you want to check if a connection between source and destination caps might be possible, use gst_caps_intersect(), which returns an intersection of the capabilities. #GstProps, #GstPad The GType of the caps boxed type, for use in GValues. A convenience macro to create a new GstCaps structure. @name: the name of the caps structure @type: the mime type of the caps structure @a...: the properties of this caps stucture. A convenience macro to create a GstCaps factory. @factoryname: the name of the factory @a...: the caps to create with this factory, usualy specified with GST_CAPS_NEW() A convenience macro to get a GstCaps from the given capsfactory. @fact: the factory to use. Check if the GstCaps is chained. @caps: the caps to query Check if the GstCaps has fixed properties, ie. it has no ranges or lists. @caps: the caps to query @name: the name of the capability, for the application @id: the typeid of the capability @refcount: a refcounter for this caps structure @fixed: a boolean indicating that this caps structure is fixed @properties: the properties of the capability @next: a pointer to the next caps. @name: @mime: @props: @Returns: @name: @id: @props: @Returns: @caps: @caps: @Returns: @caps: @Returns: @caps: @Returns: @caps: @Returns: @caps: @Returns: @caps: @Varargs: @Returns: @caps: @capstoadd: @Returns: @caps: @capstoadd: @Returns: @caps: @name: @caps: @Returns: @caps: @type_id: @caps: @Returns: @caps: @mime: @caps: @Returns: @caps: @props: @Returns: @caps: @Returns: @fromcaps: @tocaps: @Returns: Check if the GstCaps has a property with the given name @caps: the caps to query @name: the name of the property Check if the GstCaps has a fixed property with the given name @caps: the caps to query @name: the name of the property Check if the GstCaps has a property with the given type @caps: the caps to query @name: the name of the property @type: @caps: @Returns: Set a property of a caps structure. @caps: the caps structure to modify @name: the name of the property to change @args...: the new value of the property Get key/value pairs from the given GstCaps. @caps: the caps to get the values from @name: the name of the first key @args...: a pointer to the variable that can hold the result followed by more key/value pairs. @caps1: @caps2: @Returns: Get the value of the named property as a boolean. @caps: the caps to query @name: the name of the property to get @res: a pointer to a gboolean to store the result @caps: @name: @Returns: Get the value of the named property as a fourcc. @caps: the caps to query @name: the name of the property to get @res: a pointer to a guint32 to store the fourcc value Get the value of the named property as an int. @caps: the caps to query @name: the name of the property to get @res: a pointer to a gint to store the value Get the value of the named property as a string. @caps: the caps to query @name: the name of the property to get @res: a pointer to a gchar* to store the string Get the value of the named property as a float. @caps: the caps to query @name: the name of the property to get @res: a pointer to a gfloat to store the result @caps: @parent: @Returns: @parent: @Returns: @caps: @label: