diff options
-rw-r--r-- | plugins/pylon/CMakeLists.txt | 7 | ||||
-rw-r--r-- | plugins/pylon/uca-pylon-camera.c | 68 | ||||
-rw-r--r-- | plugins/pylon/uca-pylon-camera.h | 6 |
3 files changed, 75 insertions, 6 deletions
diff --git a/plugins/pylon/CMakeLists.txt b/plugins/pylon/CMakeLists.txt index f45ef76..1f56f06 100644 --- a/plugins/pylon/CMakeLists.txt +++ b/plugins/pylon/CMakeLists.txt @@ -10,9 +10,16 @@ if (PYLON_FOUND) ${CMAKE_CURRENT_BINARY_DIR}/../../package-plugin-${UCA_CAMERA_NAME}.sh) include_directories(${LIBPYLONCAM_INCLUDEDIR} + ${CMAKE_CURRENT_SOURCE_DIR} + ${CMAKE_CURRENT_BINARY_DIR} ${UCA_CONFIGDIR}) + create_enums(uca-pylon-enums + ${CMAKE_CURRENT_SOURCE_DIR}/../../src/uca-enums + uca-pylon-camera.h) + add_library(ucapylon SHARED + uca-pylon-enums.c uca-pylon-camera.c) target_link_libraries(ucapylon diff --git a/plugins/pylon/uca-pylon-camera.c b/plugins/pylon/uca-pylon-camera.c index 541b69b..97c7d35 100644 --- a/plugins/pylon/uca-pylon-camera.c +++ b/plugins/pylon/uca-pylon-camera.c @@ -19,13 +19,18 @@ #include <stdio.h> #include <string.h> #include <libpyloncam/pylon_camera.h> -#include "uca-camera.h" +#include <gmodule.h> #include "uca-pylon-camera.h" +#include "uca-pylon-enums.h" #define UCA_PYLON_CAMERA_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE((obj), UCA_TYPE_PYLON_CAMERA, UcaPylonCameraPrivate)) G_DEFINE_TYPE(UcaPylonCamera, uca_pylon_camera, UCA_TYPE_CAMERA) +#define PROP_GAIN_MIN 300 +#define PROP_GAIN_MAX 400 +#define PROP_GAIN_DEFAULT PROP_GAIN_MAX + /** * UcapylonCameraError: * @UCA_PYLON_CAMERA_ERROR_LIBPYLON_INIT: Initializing libpylon failed @@ -44,7 +49,8 @@ enum { PROP_ROI_WIDTH_DEFAULT = N_BASE_PROPERTIES, PROP_ROI_HEIGHT_DEFAULT, PROP_GAIN, - N_PROPERTIES + PROP_BALANCE_WHITE_AUTO, + N_PROPERTIES }; static gint base_overrideables[] = { @@ -102,7 +108,12 @@ UcaPylonCamera *uca_pylon_camera_new(GError **error) UcaPylonCamera *camera = g_object_new(UCA_TYPE_PYLON_CAMERA, NULL); UcaPylonCameraPrivate *priv = UCA_PYLON_CAMERA_GET_PRIVATE(camera); - pylon_camera_new("/usr/local/lib64", "141.52.111.110", error); + gchar* pylon_camera_ip = getenv("PYLON_CAMERA_IP"); + if(!pylon_camera_ip) { + g_error("no environment variable PYLON_CAMERA_IP found"); + } + + pylon_camera_new("/usr/local/lib64", pylon_camera_ip, error); if (*error != NULL) return NULL; @@ -137,7 +148,7 @@ static void uca_pylon_camera_grab(UcaCamera *camera, gpointer *data, GError **er UcaPylonCameraPrivate *priv = UCA_PYLON_CAMERA_GET_PRIVATE(camera); if (*data == NULL) { - *data = g_malloc0(priv->width * priv->height * priv->num_bytes); + *data = g_malloc0(priv->roi_width * priv->roi_height * priv->num_bytes); } pylon_camera_grab(data, error); } @@ -154,6 +165,11 @@ static void uca_pylon_camera_set_property(GObject *object, guint property_id, co /* intentional fall-through*/ case PROP_TRIGGER_MODE: break; + case PROP_BALANCE_WHITE_AUTO: + { + pylon_camera_set_int_attribute("BalanceWhiteAuto", g_value_get_enum(value), &error); + } + break; case PROP_ROI_X: { @@ -195,6 +211,14 @@ static void uca_pylon_camera_set_property(GObject *object, guint property_id, co G_OBJECT_WARN_INVALID_PROPERTY_ID(object, property_id, pspec); return; } + + if (error) { + if(error->message) { + g_warning("failed to set property %d: %s", property_id, error->message); + } else { + g_warning("failed to set property %d", property_id); + } + } } static void uca_pylon_camera_get_property(GObject *object, guint property_id, GValue *value, GParamSpec *pspec) @@ -203,6 +227,14 @@ static void uca_pylon_camera_get_property(GObject *object, guint property_id, GV GError* error = NULL; switch (property_id) { + case PROP_BALANCE_WHITE_AUTO: + { + gint enum_value = UCA_CAMERA_BALANCE_WHITE_OFF; + pylon_camera_get_int_attribute("BalanceWhiteAuto", &enum_value, &error); + UcaCameraBalanceWhiteAuto mode = enum_value; + g_value_set_enum(value, mode); + break; + } case PROP_SENSOR_WIDTH: pylon_camera_get_sensor_size(&priv->width, &priv->height, &error); g_value_set_uint(value, priv->width); @@ -313,13 +345,25 @@ static void uca_pylon_camera_get_property(GObject *object, guint property_id, GV break; case PROP_NAME: - g_value_set_string(value, "Pylon Camera"); + { + const gchar* name = NULL; + pylon_camera_get_string_attribute("ModelName", &name, &error); + g_value_set_string(value, name); + } break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID(object, property_id, pspec); break; } + if (error) { + if(error->message) { + g_warning("failed to get property %d: %s", property_id, error->message); + } else { + g_warning("failed to get property %d", property_id); + } + } + //g_debug("pylon_get_property end\n"); } static void uca_pylon_camera_finalize(GObject *object) @@ -369,7 +413,13 @@ static void uca_pylon_camera_class_init(UcaPylonCameraClass *klass) g_param_spec_int("gain", "gain", "gain", - 0, G_MAXINT, 0, + PROP_GAIN_MIN, PROP_GAIN_MAX, PROP_GAIN_DEFAULT, + G_PARAM_READWRITE); + pylon_properties[PROP_BALANCE_WHITE_AUTO] = + g_param_spec_enum("balance-white-auto", + "Balance White Auto mode", + "White balance mode (0: Off, 1: Once, 2: Continuous)", + UCA_TYPE_CAMERA_BALANCE_WHITE_AUTO, UCA_CAMERA_BALANCE_WHITE_OFF, G_PARAM_READWRITE); for (guint id = N_BASE_PROPERTIES; id < N_PROPERTIES; id++) @@ -389,3 +439,9 @@ static void uca_pylon_camera_init(UcaPylonCamera *self) self->priv->binnings = g_value_array_new(1); g_value_array_append(self->priv->binnings, &val); } + +G_MODULE_EXPORT UcaCamera * +uca_camera_impl_new (GError **error) +{ + return UCA_CAMERA(uca_pylon_camera_new(error)); +} diff --git a/plugins/pylon/uca-pylon-camera.h b/plugins/pylon/uca-pylon-camera.h index eebf63c..ed95544 100644 --- a/plugins/pylon/uca-pylon-camera.h +++ b/plugins/pylon/uca-pylon-camera.h @@ -37,6 +37,12 @@ typedef enum { UCA_PYLON_CAMERA_ERROR_UNSUPPORTED, } UcaPylonCameraError; +typedef enum { + UCA_CAMERA_BALANCE_WHITE_OFF, + UCA_CAMERA_BALANCE_WHITE_ONCE, + UCA_CAMERA_BALANCE_WHITE_CONTINUOUSLY +} UcaCameraBalanceWhiteAuto; + typedef struct _UcaPylonCamera UcaPylonCamera; typedef struct _UcaPylonCameraClass UcaPylonCameraClass; typedef struct _UcaPylonCameraPrivate UcaPylonCameraPrivate; |