summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLasse Laukkanen <ext-lasse.2.laukkanen@nokia.com>2009-03-09 18:22:28 +0200
committerRené Stadler <rene.stadler@nokia.com>2009-04-16 16:08:42 +0300
commit78b208125ab915c94f90806442b33cd4eb3d85e1 (patch)
tree87037a790273dfd4f012859b4a3a1cdc1ad1d402
parent9b0fa11a5dd25615f87e19c72611dae6acc1cc4f (diff)
downloadgst-plugins-bad-78b208125ab915c94f90806442b33cd4eb3d85e1.tar.gz
gst-plugins-bad-78b208125ab915c94f90806442b33cd4eb3d85e1.tar.bz2
gst-plugins-bad-78b208125ab915c94f90806442b33cd4eb3d85e1.zip
camerabin: clean up and fix assertion fail when setting zoom in NULL state
-rw-r--r--gst/camerabin/gstcamerabin.c84
1 files changed, 53 insertions, 31 deletions
diff --git a/gst/camerabin/gstcamerabin.c b/gst/camerabin/gstcamerabin.c
index 7657b1fc..2ddb34e0 100644
--- a/gst/camerabin/gstcamerabin.c
+++ b/gst/camerabin/gstcamerabin.c
@@ -948,46 +948,40 @@ gst_camerabin_change_filename (GstCameraBin * camera, const gchar * name)
}
}
-/*
- * gst_camerabin_setup_zoom:
- * @camera: camerabin object
- *
- * Apply zoom configured to camerabin to capture.
- */
-static void
-gst_camerabin_setup_zoom (GstCameraBin * camera)
+static gboolean
+gst_camerabin_set_photo_iface_zoom (GstCameraBin * camera, gint zoom)
{
- gint zoom;
- gboolean done = FALSE;
-
- g_return_if_fail (camera != NULL);
- g_return_if_fail (camera->src_zoom_crop != NULL);
-
- zoom = g_atomic_int_get (&camera->zoom);
-
- g_return_if_fail (zoom);
+ GstPhotography *photo = NULL;
+ GstPhotoCaps pcaps = GST_PHOTOGRAPHY_CAPS_NONE;
+ gboolean ret = FALSE;
if (GST_IS_ELEMENT (camera->src_vid_src) &&
gst_element_implements_interface (camera->src_vid_src,
GST_TYPE_PHOTOGRAPHY)) {
- /* Try setting (hardware) zoom using photography interface */
- GstPhotography *photo;
- GstPhotoCaps pcaps;
-
+ /* Try setting zoom using photography interface */
photo = GST_PHOTOGRAPHY (camera->src_vid_src);
- pcaps = gst_photography_get_capabilities (photo);
-
+ if (photo) {
+ pcaps = gst_photography_get_capabilities (photo);
+ }
if (pcaps & GST_PHOTOGRAPHY_CAPS_ZOOM) {
- done = gst_photography_set_zoom (photo, (gfloat) zoom / 100.0);
+ GST_DEBUG_OBJECT (camera, "setting zoom %d using photography interface",
+ zoom);
+ ret = gst_photography_set_zoom (photo, (gfloat) zoom / 100.0);
}
}
+ return ret;
+}
- if (!done) {
- /* Update capsfilters to apply the (software) zoom */
- gint w2_crop = 0;
- gint h2_crop = 0;
- GstPad *pad_zoom_sink = NULL;
+static gboolean
+gst_camerabin_set_element_zoom (GstCameraBin * camera, gint zoom)
+{
+ gint w2_crop = 0;
+ gint h2_crop = 0;
+ GstPad *pad_zoom_sink = NULL;
+ gboolean ret = FALSE;
+ if (camera->src_zoom_crop) {
+ /* Update capsfilters to apply the zoom */
GST_INFO_OBJECT (camera, "zoom: %d, orig size: %dx%d", zoom,
camera->width, camera->height);
@@ -1005,11 +999,39 @@ gst_camerabin_setup_zoom (GstCameraBin * camera)
GST_PAD_STREAM_LOCK (pad_zoom_sink);
g_object_set (camera->src_zoom_crop, "left", w2_crop, "right", w2_crop,
"top", h2_crop, "bottom", h2_crop, NULL);
-
GST_PAD_STREAM_UNLOCK (pad_zoom_sink);
gst_object_unref (pad_zoom_sink);
+ ret = TRUE;
+ }
+ return ret;
+}
+
+/*
+ * gst_camerabin_setup_zoom:
+ * @camera: camerabin object
+ *
+ * Apply zoom configured to camerabin to capture.
+ */
+static void
+gst_camerabin_setup_zoom (GstCameraBin * camera)
+{
+ gint zoom;
+
+ g_return_if_fail (camera != NULL);
+
+ zoom = g_atomic_int_get (&camera->zoom);
+
+ g_return_if_fail (zoom);
+
+ GST_INFO_OBJECT (camera, "setting zoom %d", zoom);
+
+ if (gst_camerabin_set_photo_iface_zoom (camera, zoom)) {
+ GST_INFO_OBJECT (camera, "zoom set using photography interface");
+ } else if (gst_camerabin_set_element_zoom (camera, zoom)) {
+ GST_INFO_OBJECT (camera, "zoom set using gst elements");
+ } else {
+ GST_INFO_OBJECT (camera, "setting zoom failed");
}
- GST_LOG_OBJECT (camera, "zoom set");
}
/*