diff options
author | Sebastian Dröge <sebastian.droege@collabora.co.uk> | 2009-04-22 19:43:22 +0200 |
---|---|---|
committer | Dave Robillard <dave@drobilla.net> | 2009-05-03 12:03:17 -0400 |
commit | c4586fe0eff622f3bf266bfd01c8f1cd2784c63b (patch) | |
tree | 79b0413defa193caa71a144557090abace5816cd /gst | |
parent | 2e78fc52c5379384b4629c8f1de4decbbb971b36 (diff) | |
download | gst-plugins-bad-c4586fe0eff622f3bf266bfd01c8f1cd2784c63b.tar.gz gst-plugins-bad-c4586fe0eff622f3bf266bfd01c8f1cd2784c63b.tar.bz2 gst-plugins-bad-c4586fe0eff622f3bf266bfd01c8f1cd2784c63b.zip |
deinterlace2: Add documentation and integrate into the build system
Diffstat (limited to 'gst')
-rw-r--r-- | gst/deinterlace2/gstdeinterlace2.c | 108 | ||||
-rw-r--r-- | gst/deinterlace2/gstdeinterlace2.h | 2 |
2 files changed, 110 insertions, 0 deletions
diff --git a/gst/deinterlace2/gstdeinterlace2.c b/gst/deinterlace2/gstdeinterlace2.c index 0440c61a..b293b43e 100644 --- a/gst/deinterlace2/gstdeinterlace2.c +++ b/gst/deinterlace2/gstdeinterlace2.c @@ -19,6 +19,20 @@ * Boston, MA 02111-1307, USA. */ +/** + * SECTION:element-deinterlace2 + * + * deinterlace2 deinterlaces interlaced video frames to progressive video frames. + * For this different algorithms can be selected which will be described later. + * + * <refsect2> + * <title>Example launch line</title> + * |[ + * gst-launch -v filesrc location=/path/to/file ! decodebin2 ! ffmpegcolorspace ! deinterlace2 ! ffmpegcolorspace ! autovideosink + * ]| This pipeline deinterlaces a video file with the default deinterlacing options. + * </refsect2> + */ + #ifdef HAVE_CONFIG_H #include "config.h" #endif @@ -482,6 +496,14 @@ gst_deinterlace2_class_init (GstDeinterlace2Class * klass) gobject_class->get_property = gst_deinterlace2_get_property; gobject_class->finalize = gst_deinterlace2_finalize; + /** + * GstDeinterlace2:mode + * + * This selects whether the deinterlacing methods should + * always be applied or if they should only be applied + * on content that has the "interlaced" flag on the caps. + * + */ g_object_class_install_property (gobject_class, PROP_MODE, g_param_spec_enum ("mode", "Mode", @@ -490,6 +512,79 @@ gst_deinterlace2_class_init (GstDeinterlace2Class * klass) DEFAULT_MODE, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS) ); + /** + * GstDeinterlace2:method + * + * Selects the different deinterlacing algorithms that can be used. + * These provide different quality and CPU usage. + * + * Some methods provide parameters which can be set by getting + * the "method" child via the #GstChildProxy interface and + * setting the appropiate properties on it. + * + * <itemizedlist> + * <listitem> + * <para> + * tomsmocomp + * Motion Adaptive: Motion Search + * </para> + * </listitem> + * <listitem> + * <para> + * greedyh + * Motion Adaptive: Advanced Detection + * </para> + * </listitem> + * <listitem> + * <para> + * greedyl + * Motion Adaptive: Simple Detection + * </para> + * </listitem> + * <listitem> + * <para> + * vfir + * Blur vertical + * </para> + * </listitem> + * <listitem> + * <para> + * linear + * Linear interpolation + * </para> + * </listitem> + * <listitem> + * <para> + * linearblend + * Linear interpolation in time domain + * </para> + * </listitem> + * <listitem> + * <para> + * scalerbob + * Double lines + * </para> + * </listitem> + * <listitem> + * <para> + * weave + * Weave + * </para> + * </listitem> + * <listitem> + * <para> + * weavetff + * Progressive: Top Field First + * </para> + * </listitem> + * <listitem> + * <para> + * weavebff + * Progressive: Bottom Field First + * </para> + * </listitem> + * </itemizedlist> + */ g_object_class_install_property (gobject_class, PROP_METHOD, g_param_spec_enum ("method", "Method", @@ -498,6 +593,13 @@ gst_deinterlace2_class_init (GstDeinterlace2Class * klass) DEFAULT_METHOD, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS) ); + /** + * GstDeinterlace2:fields + * + * This selects which fields should be output. If "all" is selected + * the output framerate will be double. + * + */ g_object_class_install_property (gobject_class, PROP_FIELDS, g_param_spec_enum ("fields", "fields", @@ -506,6 +608,12 @@ gst_deinterlace2_class_init (GstDeinterlace2Class * klass) DEFAULT_FIELDS, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS) ); + /** + * GstDeinterlace2:layout + * + * This selects which fields is the first in time. + * + */ g_object_class_install_property (gobject_class, PROP_FIELD_LAYOUT, g_param_spec_enum ("tff", "tff", diff --git a/gst/deinterlace2/gstdeinterlace2.h b/gst/deinterlace2/gstdeinterlace2.h index 1d2c3e1a..de63f54e 100644 --- a/gst/deinterlace2/gstdeinterlace2.h +++ b/gst/deinterlace2/gstdeinterlace2.h @@ -198,6 +198,8 @@ struct _GstDeinterlace2 GstPad *srcpad, *sinkpad; + /* <private> */ + GstDeinterlace2Mode mode; GstDeinterlace2FieldLayout field_layout; |