mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-24 02:31:03 +00:00
add autoprobe-fps property so we can separate autoprobing parts
Original commit message from CVS: add autoprobe-fps property so we can separate autoprobing parts
This commit is contained in:
parent
f819c223c6
commit
ae45abfb23
4 changed files with 41 additions and 7 deletions
|
@ -1,3 +1,10 @@
|
|||
2004-11-09 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||
|
||||
* sys/v4l/gstv4lsrc.c:
|
||||
* sys/v4l/gstv4lsrc.h:
|
||||
* sys/v4l/v4lsrc_calls.c:
|
||||
add autoprobe-fps property so we can separate autoprobing parts
|
||||
|
||||
2004-11-09 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||
|
||||
* sys/v4l/gstv4lsrc.c:
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
* You should have received a copy of the GNU Library General Public
|
||||
* License along with this library; if not, write to the
|
||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
* Boston, MA 02111-1307, USA.
|
||||
e Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
|
@ -32,6 +32,7 @@
|
|||
/* FIXME: small cheat */
|
||||
gboolean gst_v4l_set_window_properties (GstV4lElement * v4lelement);
|
||||
gboolean gst_v4l_get_capabilities (GstV4lElement * v4lelement);
|
||||
extern const char *v4l_palette_name[];
|
||||
|
||||
/* elementfactory information */
|
||||
static GstElementDetails gst_v4lsrc_details =
|
||||
|
@ -64,6 +65,7 @@ enum
|
|||
ARG_SYNC_MODE,
|
||||
ARG_COPY_MODE,
|
||||
ARG_AUTOPROBE,
|
||||
ARG_AUTOPROBE_FPS,
|
||||
ARG_LATENCY_OFFSET
|
||||
};
|
||||
|
||||
|
@ -213,6 +215,10 @@ gst_v4lsrc_class_init (GstV4lSrcClass * klass)
|
|||
g_param_spec_boolean ("autoprobe", "Autoprobe",
|
||||
"Whether the device should be probed for all possible features",
|
||||
TRUE, G_PARAM_READWRITE));
|
||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_AUTOPROBE_FPS,
|
||||
g_param_spec_boolean ("autoprobe-fps", "Autoprobe FPS",
|
||||
"Whether the device should be probed for framerates",
|
||||
TRUE, G_PARAM_READWRITE));
|
||||
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_LATENCY_OFFSET,
|
||||
g_param_spec_int ("latency-offset", "Latency offset",
|
||||
"A latency offset subtracted from timestamps set on buffers (in ns)",
|
||||
|
@ -278,6 +284,7 @@ gst_v4lsrc_init (GstV4lSrc * v4lsrc)
|
|||
|
||||
v4lsrc->is_capturing = FALSE;
|
||||
v4lsrc->autoprobe = TRUE;
|
||||
v4lsrc->autoprobe_fps = TRUE;
|
||||
|
||||
v4lsrc->latency_offset = 0;
|
||||
}
|
||||
|
@ -305,13 +312,18 @@ gst_v4lsrc_open (GstElement * element, const gchar * device)
|
|||
-1
|
||||
}, i;
|
||||
|
||||
GST_DEBUG_OBJECT (v4lsrc, "Checking supported palettes");
|
||||
for (i = 0; palette[i] != -1; i++) {
|
||||
/* try palette out */
|
||||
if (!gst_v4lsrc_try_capture (v4lsrc, width, height, palette[i]))
|
||||
continue;
|
||||
GST_DEBUG_OBJECT (v4lsrc, "Added palette %d (%s) to supported list",
|
||||
palette[i], v4l_palette_name[palette[i]]);
|
||||
v4lsrc->colourspaces = g_list_append (v4lsrc->colourspaces,
|
||||
GINT_TO_POINTER (palette[i]));
|
||||
}
|
||||
GST_DEBUG_OBJECT (v4lsrc, "%d palette(s) supported",
|
||||
g_list_length (v4lsrc->colourspaces));
|
||||
}
|
||||
|
||||
static void
|
||||
|
@ -326,6 +338,7 @@ gst_v4lsrc_close (GstElement * element, const gchar * device)
|
|||
/* get a list of possible framerates
|
||||
* this is only done for webcams;
|
||||
* other devices return NULL here.
|
||||
* this function takes a LONG time to execute.
|
||||
*/
|
||||
static GValue *
|
||||
gst_v4lsrc_get_fps_list (GstV4lSrc * v4lsrc)
|
||||
|
@ -799,7 +812,7 @@ gst_v4lsrc_getcaps (GstPad * pad)
|
|||
struct video_capability *vcap = &GST_V4LELEMENT (v4lsrc)->vcap;
|
||||
gfloat fps = 0.0;
|
||||
GList *item;
|
||||
GValue *fps_list;
|
||||
GValue *fps_list = NULL;
|
||||
|
||||
if (!GST_V4L_IS_OPEN (GST_V4LELEMENT (v4lsrc))) {
|
||||
return gst_caps_new_any ();
|
||||
|
@ -810,7 +823,9 @@ gst_v4lsrc_getcaps (GstPad * pad)
|
|||
}
|
||||
|
||||
/* FIXME: cache this on gst_v4l_open() */
|
||||
fps_list = gst_v4lsrc_get_fps_list (v4lsrc);
|
||||
if (v4lsrc->autoprobe_fps) {
|
||||
fps_list = gst_v4lsrc_get_fps_list (v4lsrc);
|
||||
}
|
||||
if (!fps_list)
|
||||
fps = gst_v4lsrc_get_fps (v4lsrc);
|
||||
|
||||
|
@ -1074,6 +1089,13 @@ gst_v4lsrc_set_property (GObject * object,
|
|||
}
|
||||
break;
|
||||
|
||||
case ARG_AUTOPROBE_FPS:
|
||||
if (!GST_V4L_IS_ACTIVE (GST_V4LELEMENT (v4lsrc))) {
|
||||
v4lsrc->autoprobe_fps = g_value_get_boolean (value);
|
||||
}
|
||||
break;
|
||||
|
||||
|
||||
case ARG_LATENCY_OFFSET:
|
||||
v4lsrc->latency_offset = g_value_get_int (value);
|
||||
break;
|
||||
|
@ -1120,6 +1142,10 @@ gst_v4lsrc_get_property (GObject * object,
|
|||
g_value_set_boolean (value, v4lsrc->autoprobe);
|
||||
break;
|
||||
|
||||
case ARG_AUTOPROBE_FPS:
|
||||
g_value_set_boolean (value, v4lsrc->autoprobe_fps);
|
||||
break;
|
||||
|
||||
case ARG_LATENCY_OFFSET:
|
||||
g_value_set_int (value, v4lsrc->latency_offset);
|
||||
break;
|
||||
|
|
|
@ -104,7 +104,8 @@ struct _GstV4lSrc
|
|||
GstV4lSrcSyncMode syncmode;
|
||||
|
||||
gboolean copy_mode;
|
||||
gboolean autoprobe; /* probe on startup ? */
|
||||
gboolean autoprobe; /* probe features on startup ? */
|
||||
gboolean autoprobe_fps; /* probe fps on startup ? */
|
||||
};
|
||||
|
||||
struct _GstV4lSrcClass
|
||||
|
|
|
@ -49,7 +49,7 @@ GST_DEBUG_CATEGORY_EXTERN (v4l_debug);
|
|||
|
||||
#ifndef GST_DISABLE_GST_DEBUG
|
||||
/* palette names */
|
||||
static const char *palette_name[] = {
|
||||
const char *v4l_palette_name[] = {
|
||||
"", /* 0 */
|
||||
"grayscale", /* VIDEO_PALETTE_GREY */
|
||||
"Hi-420", /* VIDEO_PALETTE_HI420 */
|
||||
|
@ -194,7 +194,7 @@ gst_v4lsrc_capture_init (GstV4lSrc * v4lsrc)
|
|||
}
|
||||
|
||||
GST_INFO_OBJECT (v4lsrc, "Got %d buffers (\'%s\') with total size %d KB",
|
||||
v4lsrc->mbuf.frames, palette_name[v4lsrc->mmap.format],
|
||||
v4lsrc->mbuf.frames, v4l_palette_name[v4lsrc->mmap.format],
|
||||
v4lsrc->mbuf.size / (v4lsrc->mbuf.frames * 1024));
|
||||
|
||||
/* keep track of queued buffers */
|
||||
|
@ -468,7 +468,7 @@ gst_v4lsrc_try_capture (GstV4lSrc * v4lsrc, gint width, gint height,
|
|||
struct video_mmap vmmap;
|
||||
|
||||
GST_DEBUG_OBJECT (v4lsrc, "try out %dx%d, palette format %d (%s)",
|
||||
width, height, palette, palette_name[palette]);
|
||||
width, height, palette, v4l_palette_name[palette]);
|
||||
GST_V4L_CHECK_OPEN (GST_V4LELEMENT (v4lsrc));
|
||||
GST_V4L_CHECK_NOT_ACTIVE (GST_V4LELEMENT (v4lsrc));
|
||||
|
||||
|
|
Loading…
Reference in a new issue