summaryrefslogtreecommitdiffstats
path: root/plugins/mock/uca-mock-camera.c
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2016-12-19 15:02:27 +0100
committerMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2016-12-19 15:02:27 +0100
commitbf58fe70946c11e655ed4e80906de2fb15aa91d5 (patch)
tree0e8dc3d669684859c5a8a99264684b98f356928d /plugins/mock/uca-mock-camera.c
parent24e9bad01e4e7e6ce4e3a5adaa44275053a42548 (diff)
downloaduca-bf58fe70946c11e655ed4e80906de2fb15aa91d5.tar.gz
uca-bf58fe70946c11e655ed4e80906de2fb15aa91d5.tar.bz2
uca-bf58fe70946c11e655ed4e80906de2fb15aa91d5.tar.xz
uca-bf58fe70946c11e655ed4e80906de2fb15aa91d5.zip
mock: emulate correct software trigger behaviour
Diffstat (limited to 'plugins/mock/uca-mock-camera.c')
-rw-r--r--plugins/mock/uca-mock-camera.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/plugins/mock/uca-mock-camera.c b/plugins/mock/uca-mock-camera.c
index 13e4175..611787d 100644
--- a/plugins/mock/uca-mock-camera.c
+++ b/plugins/mock/uca-mock-camera.c
@@ -71,6 +71,7 @@ struct _UcaMockCameraPrivate {
gboolean thread_running;
GThread *grab_thread;
+ GAsyncQueue *trigger_queue;
};
static const char g_digits[16][20] = {
@@ -311,18 +312,33 @@ uca_mock_camera_stop_recording(UcaCamera *camera, GError **error)
static void
uca_mock_camera_trigger (UcaCamera *camera, GError **error)
{
+ UcaMockCameraPrivate *priv;
+
+ g_return_if_fail(UCA_IS_MOCK_CAMERA (camera));
+ priv = UCA_MOCK_CAMERA_GET_PRIVATE (camera);
+
+ g_async_queue_push (priv->trigger_queue, g_malloc0 (1));
}
static gboolean
uca_mock_camera_grab (UcaCamera *camera, gpointer data, GError **error)
{
+ UcaMockCameraPrivate *priv;
+ UcaCameraTriggerSource trigger_source;
gdouble exposure_time;
g_return_val_if_fail (UCA_IS_MOCK_CAMERA(camera), FALSE);
- UcaMockCameraPrivate *priv = UCA_MOCK_CAMERA_GET_PRIVATE (camera);
- g_object_get (G_OBJECT (camera), "exposure-time", &exposure_time, NULL);
+ priv = UCA_MOCK_CAMERA_GET_PRIVATE (camera);
+
+ g_object_get (G_OBJECT (camera),
+ "exposure-time", &exposure_time,
+ "trigger-source", &trigger_source, NULL);
+
+ if (trigger_source == UCA_CAMERA_TRIGGER_SOURCE_SOFTWARE)
+ g_free (g_async_queue_pop (priv->trigger_queue));
+
g_usleep (G_USEC_PER_SEC * exposure_time);
if (priv->fill_data) {
@@ -455,6 +471,7 @@ uca_mock_camera_finalize(GObject *object)
}
g_free (priv->dummy_data);
+ g_async_queue_unref (priv->trigger_queue);
G_OBJECT_CLASS (uca_mock_camera_parent_class)->finalize(object);
}
@@ -554,6 +571,7 @@ uca_mock_camera_init(UcaMockCamera *self)
self->priv->bits = 8;
self->priv->bytes = 0;
self->priv->max_val = 0;
+ self->priv->trigger_queue = g_async_queue_new ();
uca_camera_register_unit (UCA_CAMERA (self), "degree-value", UCA_UNIT_DEGREE_CELSIUS);
}