X-Git-Url: https://git.ao2.it/libam7xxx.git/blobdiff_plain/120b63ecba74a2c3e31b0c8ff3e22696488cd522..700234936a4c16e3e5bc867a5abd91bf18fd422f:/src/am7xxx.h diff --git a/src/am7xxx.h b/src/am7xxx.h index 39e12e3..7d821d6 100644 --- a/src/am7xxx.h +++ b/src/am7xxx.h @@ -19,14 +19,30 @@ #ifndef __AM7XXX_H #define __AM7XXX_H -#include -#include - #ifdef __cplusplus extern "C" { #endif -typedef libusb_device_handle *am7xxx_device; + +struct _am7xxx_context; +typedef struct _am7xxx_context am7xxx_context; + +struct _am7xxx_device; +typedef struct _am7xxx_device am7xxx_device; + +typedef struct { + unsigned int native_width; + unsigned int native_height; +} am7xxx_device_info; + +typedef enum { + AM7XXX_LOG_FATAL = 0, + AM7XXX_LOG_ERROR = 1, + AM7XXX_LOG_WARNING = 2, + AM7XXX_LOG_INFO = 3, + AM7XXX_LOG_DEBUG = 4, + AM7XXX_LOG_TRACE = 5, +} am7xxx_log_level; typedef enum { AM7XXX_IMAGE_FORMAT_JPEG = 1, @@ -41,21 +57,26 @@ typedef enum { AM7XXX_POWER_TURBO = 4, } am7xxx_power_mode; -am7xxx_device am7xxx_init(void); +int am7xxx_init(am7xxx_context **ctx); + +void am7xxx_shutdown(am7xxx_context *ctx); + +void am7xxx_set_log_level(am7xxx_context *ctx, am7xxx_log_level log_level); + +int am7xxx_open_device(am7xxx_context *ctx, + am7xxx_device **dev, + unsigned int device_index); -void am7xxx_shutdown(am7xxx_device dev); +int am7xxx_close_device(am7xxx_device *dev); -int am7xxx_get_device_info(am7xxx_device dev, - unsigned int *native_width, - unsigned int *native_height, - unsigned int *unknown0, - unsigned int *unknown1); +int am7xxx_get_device_info(am7xxx_device *dev, + am7xxx_device_info *device_info); -int am7xxx_send_image(am7xxx_device dev, +int am7xxx_send_image(am7xxx_device *dev, am7xxx_image_format format, unsigned int width, unsigned int height, - uint8_t *image, + unsigned char *image, unsigned int size); /* @@ -64,7 +85,7 @@ int am7xxx_send_image(am7xxx_device dev, * * Remember to mention that when writing the API doc. */ -int am7xxx_set_power_mode(am7xxx_device dev, am7xxx_power_mode mode); +int am7xxx_set_power_mode(am7xxx_device *dev, am7xxx_power_mode mode); #ifdef __cplusplus }