summaryrefslogtreecommitdiffstats
path: root/src/cameras
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@gmail.com>2012-04-27 10:39:59 +0200
committerMatthias Vogelgesang <matthias.vogelgesang@gmail.com>2012-04-27 12:25:44 +0200
commit590c5c1522794c2f8d1bc023939aa2ce06caf35a (patch)
tree15ed7c506d06ea4f8fae0006177bc54323e68a74 /src/cameras
parenta602804ee7363cecef07b5ee64f73ef790704f0d (diff)
downloadlibuca-590c5c1522794c2f8d1bc023939aa2ce06caf35a.tar.gz
libuca-590c5c1522794c2f8d1bc023939aa2ce06caf35a.tar.bz2
libuca-590c5c1522794c2f8d1bc023939aa2ce06caf35a.tar.xz
libuca-590c5c1522794c2f8d1bc023939aa2ce06caf35a.zip
pco: add two double image mode properties
Diffstat (limited to 'src/cameras')
-rw-r--r--src/cameras/uca-pco-camera.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/cameras/uca-pco-camera.c b/src/cameras/uca-pco-camera.c
index 76ccb27..c2458c7 100644
--- a/src/cameras/uca-pco-camera.c
+++ b/src/cameras/uca-pco-camera.c
@@ -74,6 +74,8 @@ enum {
PROP_SENSOR_TEMPERATURE,
PROP_SENSOR_ADCS,
PROP_DELAY_TIME,
+ PROP_HAS_DOUBLE_IMAGE_MODE,
+ PROP_DOUBLE_IMAGE_MODE,
PROP_COOLING_POINT,
N_PROPERTIES
};
@@ -519,6 +521,13 @@ static void uca_pco_camera_set_property(GObject *object, guint property_id, cons
}
break;
+ case PROP_DOUBLE_IMAGE_MODE:
+ if (!pco_is_double_image_mode_available(priv->pco))
+ g_warning("Double image mode is not available on this pco model");
+ else
+ pco_set_double_image_mode(priv->pco, g_value_get_boolean(value));
+ break;
+
case PROP_COOLING_POINT:
{
int16_t temperature = (int16_t) g_value_get_int(value);
@@ -641,6 +650,20 @@ static void uca_pco_camera_get_property(GObject *object, guint property_id, GVal
}
break;
+ case PROP_HAS_DOUBLE_IMAGE_MODE:
+ g_value_set_boolean(value, pco_is_double_image_mode_available(priv->pco));
+ break;
+
+ case PROP_DOUBLE_IMAGE_MODE:
+ if (!pco_is_double_image_mode_available(priv->pco))
+ g_warning("Double image mode is not available on this pco model");
+ else {
+ bool on;
+ pco_get_double_image_mode(priv->pco, &on);
+ g_value_set_boolean(value, on);
+ }
+ break;
+
case PROP_HAS_STREAMING:
g_value_set_boolean(value, TRUE);
break;
@@ -784,6 +807,18 @@ static void uca_pco_camera_class_init(UcaPcoCameraClass *klass)
"Number of ADCs to use",
1, 2, 1,
G_PARAM_READWRITE);
+
+ pco_properties[PROP_HAS_DOUBLE_IMAGE_MODE] =
+ g_param_spec_boolean("has-double-image-mode",
+ "Is double image mode supported by this model",
+ "Is double image mode supported by this model",
+ FALSE, G_PARAM_READABLE);
+
+ pco_properties[PROP_DOUBLE_IMAGE_MODE] =
+ g_param_spec_boolean("use-double-image-mode",
+ "Use double image mode",
+ "Use double image mode",
+ FALSE, G_PARAM_READWRITE);
pco_properties[PROP_DELAY_TIME] =
g_param_spec_double("delay-time",