diff options
author | Matthias Vogelgesang <matthias.vogelgesang@kit.edu> | 2012-03-04 11:00:43 +0100 |
---|---|---|
committer | Matthias Vogelgesang <matthias.vogelgesang@kit.edu> | 2012-03-04 11:00:43 +0100 |
commit | 6cabdcdc0c51d567e87106d4d3222a4b89ea8f20 (patch) | |
tree | fa9bbac36aa6c12e90fde4963db5443c910be84a /src/cameras | |
parent | c6435d57e7f3f19ba5d34a77c74e7fce035a842c (diff) | |
download | uca-6cabdcdc0c51d567e87106d4d3222a4b89ea8f20.tar.gz uca-6cabdcdc0c51d567e87106d4d3222a4b89ea8f20.tar.bz2 uca-6cabdcdc0c51d567e87106d4d3222a4b89ea8f20.tar.xz uca-6cabdcdc0c51d567e87106d4d3222a4b89ea8f20.zip |
Add cooling point mechanism
Diffstat (limited to 'src/cameras')
-rw-r--r-- | src/cameras/uca-pco-camera.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/cameras/uca-pco-camera.c b/src/cameras/uca-pco-camera.c index 6362cab..b58e506 100644 --- a/src/cameras/uca-pco-camera.c +++ b/src/cameras/uca-pco-camera.c @@ -62,6 +62,7 @@ enum { N_INTERFACE_PROPERTIES, PROP_NAME, + PROP_COOLING_POINT, N_PROPERTIES }; @@ -150,6 +151,21 @@ static guint fill_binnings(UcaPcoCameraPrivate *priv) return err; } +static guint override_temperature_range(UcaPcoCameraPrivate *priv) +{ + int16_t default_temp, min_temp, max_temp; + guint err = pco_get_cooling_range(priv->pco, &default_temp, &min_temp, &max_temp); + + if (err == PCO_NOERROR) { + GParamSpecInt *spec = (GParamSpecInt *) pco_properties[PROP_COOLING_POINT]; + spec->minimum = min_temp; + spec->maximum = max_temp; + spec->default_value = default_temp; + } + + return err; +} + UcaPcoCamera *uca_pco_camera_new(GError **error) { /* TODO: find a good way to handle libpco and fg errors */ @@ -210,6 +226,12 @@ UcaPcoCamera *uca_pco_camera_new(GError **error) fill_binnings(priv); + /* + * Here we override the temperature property range because this was not + * possible at property installation time. + */ + override_temperature_range(priv); + return camera; } @@ -235,6 +257,12 @@ static void uca_pco_camera_set_property(GObject *object, guint property_id, cons UcaPcoCameraPrivate *priv = UCA_PCO_CAMERA_GET_PRIVATE(object); switch (property_id) { + case PROP_COOLING_POINT: + { + int16_t temperature = (int16_t) g_value_get_int(value); + pco_set_cooling_temperature(priv->pco, temperature); + } + break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID(object, property_id, pspec); return; @@ -291,6 +319,14 @@ static void uca_pco_camera_get_property(GObject *object, guint property_id, GVal } break; + case PROP_COOLING_POINT: + { + int16_t temperature; + pco_get_cooling_temperature(priv->pco, &temperature); + g_value_set_int(value, temperature); + } + break; + default: G_OBJECT_WARN_INVALID_PROPERTY_ID(object, property_id, pspec); break; @@ -341,6 +377,17 @@ static void uca_pco_camera_class_init(UcaPcoCameraClass *klass) "Name of the camera", "", G_PARAM_READABLE); + /* + * The default values here are set arbitrarily, because we are not yet + * connected to the camera and just don't know the cooling range. We + * override these values in uca_pco_camera_new(). + */ + pco_properties[PROP_COOLING_POINT] = + g_param_spec_int("cooling-point", + "Cooling point of the camera", + "Cooling point of the camera", + 0, 10, 5, G_PARAM_READWRITE); + for (guint id = N_INTERFACE_PROPERTIES + 1; id < N_PROPERTIES; id++) g_object_class_install_property(gobject_class, id, pco_properties[id]); |