Top |
void | (*ArvFrameCallback) () |
ArvBuffer * | arv_buffer_new () |
ArvBuffer * | arv_buffer_new_full () |
ArvBuffer * | arv_buffer_new_allocate () |
const void * | arv_buffer_get_user_data () |
const void * | arv_buffer_get_data () |
const void * | arv_buffer_get_chunk_data () |
guint64 | arv_buffer_get_timestamp () |
void | arv_buffer_set_timestamp () |
guint64 | arv_buffer_get_system_timestamp () |
void | arv_buffer_set_system_timestamp () |
guint32 | arv_buffer_get_frame_id () |
ArvBufferPayloadType | arv_buffer_get_payload_type () |
ArvBufferStatus | arv_buffer_get_status () |
gint | arv_buffer_get_image_height () |
ArvPixelFormat | arv_buffer_get_image_pixel_format () |
void | arv_buffer_get_image_region () |
gint | arv_buffer_get_image_width () |
gint | arv_buffer_get_image_x () |
gint | arv_buffer_get_image_y () |
#define | ARV_PIXEL_FORMAT_BIT_PER_PIXEL() |
ArvBuffer provides a class for the instantiation of buffers used for the storage of the separate images of the video stream. The actual data space may either be allocated by ArvBuffer during an object instatiation, of preallocated. ArvBuffer also allows the transmission of image metadata, such as offsets and size of the transmitted region of interrest, pixel format and time stamp.
ArvBuffer * arv_buffer_new (size_t size
,void *preallocated
);
Creates a new buffer for the storage of the video stream images. The data space can be either preallocated, and the caller is responsible for it's deallocation, or allocated by this function. If it is the case, data memory will be freed when the buffer is destroyed.
Since: 0.2.0
ArvBuffer * arv_buffer_new_full (size_t size
,void *preallocated
,void *user_data
,GDestroyNotify user_data_destroy_func
);
Creates a new buffer for the storage of the video stream images. The data space can be either preallocated, and the caller is responsible for it's deallocation, or allocated by this function. If it is the case, data memory will be freed when the buffer is destroyed.
If user_data_destroy_func
is non NULL, it will be called in order to destroy
user_data when the buffer is destroyed.
size |
payload size |
|
preallocated |
preallocated memory buffer. |
[transfer none] |
user_data |
a pointer to user data associated to this buffer. |
[transfer none] |
user_data_destroy_func |
an optional user data destroy callback |
Since: 0.2.0
ArvBuffer *
arv_buffer_new_allocate (size_t size
);
Creates a new buffer for the storage of the video stream images. The data space is allocated by this function, and will be freed when the buffer is destroyed.
Since: 0.2.3
const void *
arv_buffer_get_user_data (ArvBuffer *buffer
);
Gets a pointer to user data set by arv_buffer_new_full.
Since: 0.4.0
const void * arv_buffer_get_data (ArvBuffer *buffer
,size_t *size
);
Buffer data accessor.
Since: 0.4.0
const void * arv_buffer_get_chunk_data (ArvBuffer *buffer
,guint64 chunk_id
,size_t *size
);
Chunk data accessor.
Since: 0.4.0
guint64
arv_buffer_get_timestamp (ArvBuffer *buffer
);
Gets the buffer camera timestamp, expressed as nanoseconds. Not all devices
provide reliable timestamp, which means sometimes its better to rely on the
buffer completion host local time, or to use
arv_buffer_get_system_timestamp()
.
Since: 0.4.0
void arv_buffer_set_timestamp (ArvBuffer *buffer
,guint64 timestamp_ns
);
Sets the buffer timestamp, which allows to override the timpestamp set by the camera, which in some case is incorrect.
Since: 0.4.0
guint64
arv_buffer_get_system_timestamp (ArvBuffer *buffer
);
Gets the system timestamp for when the frame was received. Expressed in nanoseconds.
Since: 0.6.0
void arv_buffer_set_system_timestamp (ArvBuffer *buffer
,guint64 timestamp_ns
);
Sets the system timestamp for when the frame was received. Expressed in nanoseconds.
Since: 0.6.0
guint32
arv_buffer_get_frame_id (ArvBuffer *buffer
);
Gets the buffer frame id. For GigEVision devices, valid values are in the 1..65535 range.
Since: 0.4.0
ArvBufferPayloadType
arv_buffer_get_payload_type (ArvBuffer *buffer
);
Gets the buffer payload type.
Since: 0.4.0
ArvBufferStatus
arv_buffer_get_status (ArvBuffer *buffer
);
Gets the buffer acquisition status.
Since: 0.4.0
gint
arv_buffer_get_image_height (ArvBuffer *buffer
);
Gets the image width. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
Since: 0.4.0
ArvPixelFormat
arv_buffer_get_image_pixel_format (ArvBuffer *buffer
);
Gets the image pixel format. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
Since: 0.4.0
void arv_buffer_get_image_region (ArvBuffer *buffer
,gint *x
,gint *y
,gint *width
,gint *height
);
Gets the image region. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
buffer |
||
x |
image x offset placeholder. |
[allow-none] |
y |
image y offset placeholder. |
[allow-none] |
width |
image width placholder. |
[allow-none] |
height |
image height placeholder. |
[allow-none] |
Since: 0.4.0
gint
arv_buffer_get_image_width (ArvBuffer *buffer
);
Gets the image width. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
Since: 0.4.0
gint
arv_buffer_get_image_x (ArvBuffer *buffer
);
Gets the image x offset. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
Since: 0.4.0
gint
arv_buffer_get_image_y (ArvBuffer *buffer
);
Gets the image y offset. This function must only be called on buffer containing a ARV_BUFFER_PAYLOAD_TYPE_IMAGE
payload.
Since: 0.4.0
unknown status |
||
the buffer contains a valid image |
||
the buffer is cleared |
||
timeout was reached before all packets are received |
||
stream has missing packets |
||
stream has packet with wrong id |
||
the received image didn't fit in the buffer data space |
||
the image is currently being filled |
||
the filling was aborted before completion |
#define ARV_PIXEL_FORMAT_CUSTOM_BAYER_BG_12_PACKED 0x810c0004
#define ARV_PIXEL_FORMAT_CUSTOM_BAYER_GB_12_PACKED 0x810c0003
#define ARV_PIXEL_FORMAT_CUSTOM_BAYER_GR_12_PACKED 0x810c0001
#define ARV_PIXEL_FORMAT_CUSTOM_BAYER_RG_12_PACKED 0x810c0002
#define ARV_PIXEL_FORMAT_CUSTOM_YUV_422_YUYV_PACKED 0x82100005
#define ARV_PIXEL_FORMAT_MONO_14 0x01100025 /* https://bugzilla.gnome.org/show_bug.cgi?id=655131 */