diff options
| author | Matthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de> | 2011-03-17 13:55:53 +0100 | 
|---|---|---|
| committer | Matthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de> | 2011-03-17 13:55:53 +0100 | 
| commit | 65a2016becbb165afa4fdf16742f3586f83d0f30 (patch) | |
| tree | 6cc4dcd57c5af48d3732b8aa855adbd710376a28 /src | |
| parent | 35681d4e1d171117c9d4c2c4fd7d474b5871f81f (diff) | |
| download | uca-65a2016becbb165afa4fdf16742f3586f83d0f30.tar.gz uca-65a2016becbb165afa4fdf16742f3586f83d0f30.tar.bz2 uca-65a2016becbb165afa4fdf16742f3586f83d0f30.tar.xz uca-65a2016becbb165afa4fdf16742f3586f83d0f30.zip | |
Allow resize of image dimensions
Diffstat (limited to 'src')
| -rw-r--r-- | src/cameras/dummy.c | 30 | ||||
| -rw-r--r-- | src/uca.h | 1 | 
2 files changed, 25 insertions, 6 deletions
| diff --git a/src/cameras/dummy.c b/src/cameras/dummy.c index d71940e..ba95a67 100644 --- a/src/cameras/dummy.c +++ b/src/cameras/dummy.c @@ -5,17 +5,33 @@  #include "uca-cam.h"  #include "uca-grabber.h" -struct dummy_cam_t { +typedef struct dummy_cam {      uint32_t bitdepth;      uint32_t framerate;      char*   buffer; -}; +} dummy_cam_t; -#define GET_DUMMY(uca) ((struct dummy_cam_t *)(uca->user)) +#define GET_DUMMY(uca) ((struct dummy_cam *)(uca->user))  #define set_void(p, type, value) { *((type *) p) = value; }  static uint32_t uca_dummy_set_property(struct uca_camera *cam, enum uca_property_ids property, void *data)  { +    if (cam->state == UCA_CAM_RECORDING) +        return UCA_ERR_PROP_CAMERA_RECORDING; + +    switch (property) { +        case UCA_PROP_WIDTH: +            cam->frame_width = *((uint32_t *) data); +            break; + +        case UCA_PROP_HEIGHT: +            cam->frame_height = *((uint32_t *) data); +            break; + +        default: +            return UCA_ERR_PROP_INVALID; +    } +      return UCA_NO_ERROR;  } @@ -63,11 +79,13 @@ static uint32_t uca_dummy_get_property(struct uca_camera *cam, enum uca_property  uint32_t uca_dummy_start_recording(struct uca_camera *cam)  {      cam->current_frame = 0; +    cam->state = UCA_CAM_RECORDING;      return UCA_NO_ERROR;  }  uint32_t uca_dummy_stop_recording(struct uca_camera *cam)  { +    cam->state = UCA_CAM_ARMED;      return UCA_NO_ERROR;  } @@ -134,7 +152,7 @@ static const char digits[10][20] = {        0xff, 0xff, 0xff, 0x00 }  }; -static void uca_dummy_print_number(struct dummy_cam_t *dummy, int number, int x, int y, int width) +static void uca_dummy_print_number(struct dummy_cam *dummy, int number, int x, int y, int width)  {      const int digit_width = 4;      const int digit_height = 5; @@ -148,7 +166,7 @@ static void uca_dummy_print_number(struct dummy_cam_t *dummy, int number, int x,  uint32_t uca_dummy_grab(struct uca_camera *cam, char *buffer)  { -    struct dummy_cam_t *dummy = GET_DUMMY(cam); +    struct dummy_cam *dummy = GET_DUMMY(cam);      dummy->buffer = buffer;      /* print current frame number */ @@ -185,7 +203,7 @@ uint32_t uca_dummy_init(struct uca_camera **cam, struct uca_grabber *grabber)      uca->frame_height = 240;      uca->current_frame = 0; -    struct dummy_cam_t *dummy_cam = (struct dummy_cam_t *) malloc(sizeof(struct dummy_cam_t)); +    struct dummy_cam *dummy_cam = (struct dummy_cam *) malloc(sizeof(struct dummy_cam));      dummy_cam->bitdepth = 8;      dummy_cam->framerate = 100;      dummy_cam->buffer = NULL; @@ -203,6 +203,7 @@ enum uca_errors {      UCA_ERR_PROP_INVALID,               /**< the requested property is not supported by the camera */      UCA_ERR_PROP_GENERAL,               /**< error occured reading/writing the property */      UCA_ERR_PROP_VALUE_OUT_OF_RANGE,    /**< error occured writing the property */ +    UCA_ERR_PROP_CAMERA_RECORDING,      /**< cannot set/get property because camera is recording */      UCA_ERR_CAM_ARM,                    /**< camera is not armed */      UCA_ERR_CAM_RECORD,                 /**< could not record */ | 
