Syntax
PXL_RETURN_CODE PxLSetEventCallback ( HANDLE hCamera, U32 eventId, LPVOID pContext, U32 (PXL_APICALL* EventProcessFunction)( HANDLE hCamera, U32 eventId, double eventTimestamp, U32 numDataBytes, LPVOID pData, LPVOID pContext ) );
Description
This function installs a user defined callback that will be called by the API whenever the specified event occurs in the specified camera.
hCamera is the camera handle. This value is returned by PxLInitializeEx.
eventId identifies the specific event. The entire set of possible events can be found here: Event ID
pContext is a parameter that can be used to have additional information passed to your callback function. It is optional, and can be NULL.
EventProcessFunction is a function pointer to a user-defined callback function. This function will be called by the API with the following parameters:
hCamera is the camera handle. This value is returned by PxLInitializeEx.
eventId identifies the specific event.
eventTimestamp identifies the specific time within the camera, when the event occurred. The application can get the camera’s time via the function PxLGetCurrentTimestamp.
numDataBytes is the number of data bytes associated with the event (the number of bytes pointed to by pData). At present, this is always 0
pData is an array of numDataBytes bytes, representing event specific data. Currently, none of the defined events have any associated data (so this value will be NULL).
pContext is the value that was passed as the pContext parameter to PxLSetEventCallback.
Example
U32 userData = 0x5AFECAFE; rc = PxLSetEventCallback( hCamera, EVENT_ANY, // We can specify a specific event, or all of them (LPVOID)userData, EventCallbackFunc); if (!API_SUCCESS(rc)) { // Error handling here } Sleep (STALL_TIME); PxLSetEventCallback (hCamera, EVENT_ANY, NULL, NULL); // Cancel the callback
Comments, Restrictions and Limitations
Similar to frame callbacks, event callbacks do not persist across camera power cycles – a camera reset effectively cancels all callback requests. Also, callbacks are not saved as part of the camera settings with PxLSave/LoadCameraSettings operations.