Smart RecordΒΆ
-
group
gstreamer_nvdssr
Specifies APIs relating to smart recording.
Typedefs
-
typedef struct NvDsSRRecordingInfo
NvDsSRRecordingInfo
Hold information about video recorded.
-
typedef gpointer (*
NvDsSRCallbackFunc
)(NvDsSRRecordingInfo *info, gpointer userData)
-
typedef guint32
NvDsSRSessionId
-
typedef struct NvDsSRInitParams
NvDsSRInitParams
Holds initializtion paramerters required to create NvDsSRContext.
-
typedef struct NvDsSRContext
NvDsSRContext
Holds information about smart record instance.
Enums
-
enum
NvDsSRContainerType
Specifies container types.
Values:
-
enumerator
NVDSSR_CONTAINER_MP4
-
enumerator
NVDSSR_CONTAINER_MKV
-
enumerator
-
enum
NvDsSRStatus
Specifies API return status.
Values:
-
enumerator
NVDSSR_STATUS_OK
-
enumerator
NVDSSR_STATUS_INVALID_VAL
-
enumerator
NVDSSR_STATUS_INVALID_OP
-
enumerator
NVDSSR_STATUS_ERROR
-
enumerator
NVDSSR_STATUS_CUSTOM1
-
enumerator
NVDSSR_STATUS_CUSTOM2
-
enumerator
NVDSSR_STATUS_CUSTOM3
-
enumerator
Functions
-
NvDsSRStatus
NvDsSRCreate
(NvDsSRContext **ctx, NvDsSRInitParams *params) Creates the instance of smart record.
This function creates the instance of smart record and returns the pointer to an allocated NvDsSRContext. The params structure must be filled with initialization parameters required to create the instance.
recordbin of NvDsSRContext is smart record bin which must be added to the pipeline. It expects encoded frames which will be muxed and saved to the file. Add this bin after parser element in the pipeline.
Call NvDsSRDestroy() to free resources allocated by this function.
- Return
NVDSSR_STATUS_OK if successful, or corresponding error otherwise.
- Parameters
[out] ctx
: An indirect pointer to the smart record instance.[in] params
: A pointer to a NvDsSRInitParams structure.
-
NvDsSRStatus
NvDsSRStart
(NvDsSRContext *ctx, NvDsSRSessionId *sessionId, guint startTime, guint duration, gpointer userData) Starts the video recording.
This function starts writing the cached video data to a file. It returns the session id which later can be used in NvDsSRStop() to stop the corresponding recording.
Here startTime specifies the seconds before the current time and duration specifies the seconds after the start of recording. If current time is t1, content from t1 - startTime to t1 + duration will be saved to file. Therefore a total of startTime + duration seconds of data will be recorded.
- Return
NVDSSR_STATUS_OK if successful, or corresponding error otherwise.
- Parameters
[in] ctx
: A pointer to a NvDsSRContext.[out] sessionId
: A pointer to a NvDsSRSessionId.[in] startTime
: Seconds before the current time. Should be less than video cache size.[in] duration
: Duration value in seconds after the start of recording.[in] userData
: A pointer to user specified data.
-
NvDsSRStatus
NvDsSRStop
(NvDsSRContext *ctx, NvDsSRSessionId sessionId) Stops the previously started recording.
- Return
NVDSSR_STATUS_OK if successful, or corresponding error otherwise.
- Parameters
[in] ctx
: A pointer to a NvDsSRContext.[in] sessionId
: Id of seesion to stop.
-
NvDsSRStatus
NvDsSRDestroy
(NvDsSRContext *ctx) Destroys the instance of smart record.
This function releases the resources previously allocated by NvDsSRCreate().
- Return
NVDSSR_STATUS_OK if successful, or corresponding error otherwise.
- Parameters
[in] ctx
: A pointer to a NvDsSRContext to be freed.
-
struct
NvDsSRInitParams
- #include <gst-nvdssr.h>
Holds initializtion paramerters required to create NvDsSRContext.
-
struct
NvDsSRContext
- #include <gst-nvdssr.h>
Holds information about smart record instance.
-
struct
NvDsSRRecordingInfo
- #include <gst-nvdssr.h>
Hold information about video recorded.
-
typedef struct NvDsSRRecordingInfo