Media Streams

Detailed Description

Access to video audio and data streams from an Encoder.

Media Stream Component

The features provided by the SDK are divided between those required to provide an end user application for monitoring multiple media streams and those required to administer the Server, Encoders and user access rights. This section details the features offered by the SDK required to build a monitoring application.

In order to access a media stream it is necessary to first connect to a Server using the Server object which gives access to the available Encoders.

Media Stream Data

An Encoder can deliver a media stream that can include video, stereo audio and metadata. To access a media stream it is necessary to obtain and open the stream from the Encoder object. This request will (assuming there are no other users receiving the media stream) instruct the Encoder to provide the media stream to the Server which in turn will forward the stream to the client. A media stream is only generated if there is at least one recipient of that stream.

Once opened the Stream data is returned in callback interfaces to the client application. Access the contents of the stream will depend on the permissions, configuration and deployment of the Encoder:

Video Frames

The decompressed video frames are provided as raw YCbCr 4:2:0 frames where the SDK includes helper functions to support conversion to RGB bitmaps and save JPEG or BMP images.

Each video frame is uniquely identified by a UTC timestamps corresponding to the time at capture. Additional information supplied with each frame includes a flag indicating that the frame has been assigned to the Encoder frame buffer and an aspect ratio modifier that should be applied as part of the frame render process.

Audio Frames

The audio, if enabled, will be delivered as frames of 16-bit PCM samples. According to the Encoder configuration these frames will represent mono or stereo audio. Each audio frame is uniquely identified by a UTC timestamp corresponding to the time at capture.

GPS Data

Where a GPS device is attached to the Encoder, geospatial metadata is included in the media stream. Geospatial metadata is treated as a special case with respect to its insertion into the media stream in order to ensure that positional information is matched to the corresponding video and audio.

Pass-Thru Data

Where a third-party device is attached to the Encoder and the serial port has been configured to receive data from that device it can be broadcast to viewers in the media stream (one-to-many). The data is received in packets of raw arrays of bytes for interpretation by the application.

SCT Data

This allows the application developer to obtain the raw compressed media stream. This stream can be saved to file and can later be passed through a decoder that will deliver all the media contained in the stream.

Sample applications

Full sample applications are available demonstrating the capabilities of the SDK

See Sample applications

Classes

struct  AnalyticsActorPoint
 Describes an analytics actor points. More...
 
struct  AnalyticsActorInfo
 Describes an analytics actor data object being received. More...
 
class  EdgeVisDecoderSDK::AnalyticsActorInfo
 Encoders equipped with SafeZone 2D analytics will return an actor when an object is detected. More...
 
class  EdgeVisDecoderSDK::AnalyticsData
 Encoders equipped with SafeZone 2D analytics will return analytics data when an object is detected. More...
 
class  EdgeVisDecoderSDK::AudioData
 AudioData is delivered for every frame of audio decoded from a media stream. More...
 
class  EdgeVisDecoderSDK::CameraPositionData
 If the encoder has camera position data it will return this information as part of the stream data. More...
 
class  EdgeVisDecoderSDK::CommandData
 A command received by the dewclaw library. More...
 
class  EdgeVisDecoderSDK::EncoderMetaData
 An Event received from the Encoder by the decoder library. More...
 
class  EdgeVisDecoderSDK::EventData
 An Event received from the Encoder by the decoder library. More...
 
class  EdgeVisDecoderSDK::FrameConfig
 This is the base class for the FrameConfig objects. More...
 
class  EdgeVisDecoderSDK::GPSData
 If the encoder has live GPS data it will return location information as part of the stream data. More...
 
class  EdgeVisDecoderSDK::H264Frame
 An H264Frame object provides H.264 (Annex B) data from the MediaStream to the applicaiton. More...
 
class  EdgeVisDecoderSDK::H264FrameConfig
 This is the derived class for the H264FrameConfig objects. More...
 
class  EdgeVisDecoderSDK::IndexedSCTData
 An Indexed SCT Data block. More...
 
class  EdgeVisDecoderSDK::IServiceListener
 Defines an interface for a class that listens for incoming state changes from a service. More...
 
class  EdgeVisDecoderSDK::IStreamListener
 Defines an interface for a class that listens for incoming data from a Stream. More...
 
class  EdgeVisDecoderSDK::JPEGFrame
 A JPEGFrame is designed for transforming YCbCr colour space frames into an in memory JPEG frame buffer. More...
 
class  EdgeVisDecoderSDK::JPEGFrameConfig
 This is the derived class for the JPEGFrameConfig objects. More...
 
class  EdgeVisDecoderSDK::MediaStream
 A MediaStream is a Stream class that provides additional methods and properties specific to the Media Stream. More...
 
class  EdgeVisDecoderSDK::OnvifMetadata
 Provides analytics data in ONVIF XML format: https://www.onvif.org/specs/srv/analytics/ONVIF-VideoAnalytics-Service-Spec-v210.pdf. More...
 
class  EdgeVisDecoderSDK::RGBFrame
 An RGBFrame is designed for transforming YCbCr colour space frames into RGB colour space frames. More...
 
class  EdgeVisDecoderSDK::SnapshotFrame
 A SnapshotFrame is an extension of YCbCrFrame. More...
 
class  EdgeVisDecoderSDK::Stream
 The Stream interface represent a service that is available on an Encoder. More...
 
class  EdgeVisDecoderSDK::StreamData
 This is the base class for the StreamData objects. More...
 
class  EdgeVisDecoderSDK::VideoData
 The VideoData class extends the StreamData class and is a base class for all types of video data provided by the MediaStream. More...
 
class  EdgeVisDecoderSDK::YCbCrFrame
 An YCbCrFrame is delivered for every frame of video decoded from a media stream. More...
 

Typedefs

typedef struct AnalyticsActorPoint AnalyticsActorPoint
 Describes an analytics actor points. More...
 
typedef struct AnalyticsActorInfo AnalyticsActorInfo
 Describes an analytics actor data object being received. More...
 
typedef enum AudioFormat AudioFormat
 Audio data format.
 
typedef enum H264FrameType H264FrameType
 H.264 frame types that may be provided by the MediaStream.
 
typedef enum EdgeVisDecoderSDK::IndexedPacketType EdgeVisDecoderSDK::IndexedPacketType
 Contains the type of IndexedSCTData
 
typedef enum RGBFormat RGBFormat
 RGB formats supported by the RGBFrame Convert method.
 
typedef enum StreamStatus StreamStatus
 Stream status information types.
 
typedef enum StreamTimestampContext StreamTimestampContext
 Stream timestamp context.
 
typedef enum EdgeVisDecoderSDK::StreamType EdgeVisDecoderSDK::StreamType
 Defines the type of stream.
 
typedef enum VideoCodecMode VideoCodecMode
 These are used by the EncoderConfig class to represent the codec modes available.
 
typedef enum VideoSourceFormat VideoSourceFormat
 The type of video source in use at the encoder.
 

Enumerations

Typedef Documentation

Describes an analytics actor points.

The points represent the track of the actor across the scene. The Points will update as the actor moves across the scene.

Describes an analytics actor data object being received.

Enumeration Type Documentation

enum AudioFormat
strong

Audio data format.

Enumerator
PCM16 

PCM 16-bit.

G711_ULAW 

G711 ulaw.

UNKNOWN 

Unknown.

H.264 frame types that may be provided by the MediaStream.

Enumerator
H264_Unknown_Frame 

Unknown H.264 frame type.

H264_I_Frame 

H.264 intra frame type.

H264_P_Frame 

H.264 predicted frame type.

Contains the type of IndexedSCTData

Enumerator
IPT_Corrupt 

Frame is corrupt.

IPT_Frame 

Normal frame of data.

IPT_KeyFrame 

A ket frame.

enum RGBFormat

RGB formats supported by the RGBFrame Convert method.

Enumerator
RGB_Format_ARGB 

ARGB 4 bytes per pixel.

RGB_Format_BGRA 

BGRA 4 bytes per pixel.

RGB_Format_ABGR 

ABGR 4 bytes per pixel.

RGB_Format_RGBA 

RGBA 4 bytes per pixel.

RGB_Format_BGR24 

BGR24 3 bytes per pixel.

RGB_Format_RGB24 

RGB24 3 bytes per pixel.

RGB_Format_RGB565 

RGBA565 2 bytes per pixel.

RGB_Format_ARGB1555 

ARGB1555 2 bytes per pixel.

RGB_Format_ARGB4444 

ARGB4444 2 bytes per pixel.

RGB_Format_Unknown 

Unknown RGB format.

Stream status information types.

Enumerator
SS_StreamOk 

Stream is OK (might be trying to connect)

SS_StreamTempUnavailable 

Stream is unavailable.

Attempting reconnect

SS_StreamNotFound 

Stream not available.

Permissions issue?

SS_StreamKicked 

Stream closed on the server side by Admin.

SS_StreamClosed 

Stream has been closed.

SS_ServerDown 

Cant contact server so stream will be down.

SS_StreamInvalidated 

The stream has been removed (deleted).

SS_VideoStarted 

Video has started playing.

SS_VideoStopped 

Video has stopped playing.

SS_Sending 

Sending (Serial mode only)

SS_Receiving 

Receiving (Serial mode only)

SS_ArchiveVideoStarted 

Archive video has started playing.

SS_ArchiveVideoStopped 

Archive video has stopped playing.

SS_StreamInUse 

The requested stream is locked by another user.

SS_StreamIncompatible 

The stream version from the encoder is newer than the decoder can support.

SS_StreamTimedOut 

Stream has timed out.

SS_StreamTransportFailed 

Stream has not been able to connect using the specified transport and may try a secondary option.

SS_StreamConnectFailed 

Stream has failed to connect.

SS_StreamKeyFrameDecoded 

Stream decoded a key frame.

SS_StreamCorrupt 

Stream corruption detected, a key frame will be requested automatically.

SS_DecodePerformanceSlow 

The decode is unable to keep pace with the incoming data, could be due to too many streams on one machine.

SS_H264FrameSkipped 

The H264 Encoder is skipping frames.

SS_H264EncodeFailed 

The H264 Encoder has failed to skip a frame.

SS_RGBEncodeFailed 

The RGB Encoder has failed to encode a frame.

SS_JPEGEncodeFailed 

The JPEG Encoder has failed to encode a frame.

Stream timestamp context.

Enumerator
STC_Invalid 

Stream timestamp is not valid.

STC_Live 

Stream timestamp corresponds to live video.

STC_Archive 

Stream timestamp corresponds to archive video.

STC_FullRes 

Stream timestamp corresponds to a frame from the full-res cache.

Defines the type of stream.

Enumerator
ST_GenericStream 

A generic stream.

ST_MediaStream 

A media stream with video, audio and GPS data.

ST_DataStream 

A data stream.

ST_PassThruStream 

A serial passthru stream.

ST_PTZStream 

A PTZ stream.

ST_FullResService 

A Full resolution stream.

ST_ArchiveDownloadService 

An archive download stream.

ST_SecureConnectService 

A secure connect stream.

ST_GOPDownloadService 

A GOP download stream.

ST_AnalyticsStream 

An analytics stream.

These are used by the EncoderConfig class to represent the codec modes available.

Enumerator
VCM_NotSupported 

For Encoder models that do not support this mode.

(C310, IP series etc)

VCM_FixedFrameSize 

Fix the frame size, the frame rate will vary (HD-S600, R700)

VCM_FixedFrameRate 

Fix the frame rate, the frame size will vary (HD-S600, R700)

VCM_Max 

Fix the frame rate, the frame size will vary (HD-S600, R700)

The type of video source in use at the encoder.

Enumerator
Video_Source_PAL 

Video source is PAL.

Video_Source_NTSC 

Video source is NTSC.

Video_Source_Other 

Video source is HD.