summaryrefslogtreecommitdiffstats
path: root/plugins/pco
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/pco')
-rw-r--r--plugins/pco/uca-pco-camera.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/plugins/pco/uca-pco-camera.c b/plugins/pco/uca-pco-camera.c
index 8ccee1c..71b973c 100644
--- a/plugins/pco/uca-pco-camera.c
+++ b/plugins/pco/uca-pco-camera.c
@@ -129,6 +129,7 @@ enum {
PROP_RECORD_MODE,
PROP_STORAGE_MODE,
PROP_ACQUIRE_MODE,
+ PROP_FAST_SCAN,
PROP_COOLING_POINT,
PROP_COOLING_POINT_MIN,
PROP_COOLING_POINT_MAX,
@@ -816,6 +817,9 @@ uca_pco_camera_set_property(GObject *object, guint property_id, const GValue *va
if (pixel_rate != 0) {
err = pco_set_pixelrate(priv->pco, pixel_rate);
+
+ if (err != PCO_NOERROR)
+ err = pco_reset(priv->pco);
}
else
g_warning("%i Hz is not possible. Please check the \"sensor-pixelrates\" property", desired_pixel_rate);
@@ -881,6 +885,15 @@ uca_pco_camera_set_property(GObject *object, guint property_id, const GValue *va
}
break;
+ case PROP_FAST_SCAN:
+ {
+ guint32 mode;
+
+ mode = g_value_get_boolean (value) ? PCO_SCANMODE_FAST : PCO_SCANMODE_SLOW;
+ pco_set_scan_mode (priv->pco, mode);
+ }
+ break;
+
case PROP_TRIGGER_MODE:
{
UcaCameraTrigger trigger_mode = (UcaCameraTrigger) g_value_get_enum(value);
@@ -1187,6 +1200,14 @@ uca_pco_camera_get_property (GObject *object, guint property_id, GValue *value,
}
break;
+ case PROP_FAST_SCAN:
+ {
+ guint32 mode;
+ err = pco_get_scan_mode (priv->pco, &mode);
+ g_value_set_boolean (value, mode == PCO_SCANMODE_FAST);
+ }
+ break;
+
case PROP_TRIGGER_MODE:
{
guint16 mode;
@@ -1496,6 +1517,12 @@ uca_pco_camera_class_init(UcaPcoCameraClass *klass)
UCA_TYPE_PCO_CAMERA_ACQUIRE_MODE, UCA_PCO_CAMERA_ACQUIRE_MODE_AUTO,
G_PARAM_READWRITE);
+ pco_properties[PROP_FAST_SCAN] =
+ g_param_spec_boolean("fast-scan",
+ "Use fast scan mode",
+ "Use fast scan mode with less dynamic range",
+ FALSE, G_PARAM_READWRITE);
+
pco_properties[PROP_NOISE_FILTER] =
g_param_spec_boolean("noise-filter",
"Noise filter",