Public API (v3.1)
Hints:
protocol in ObjC/Swift is interface in Java; delegate in ObjC/Swift is listener in Java.
All class names in ObjC/Swift starts with prefix "CM" (i.e CMAccessTokenProvider etc).
CameraStreamer (v3.1)
Hints:
- In case of multiple CameraStreamer instances usage it's generally advised to mute audio on all or all except one CameraStreamer instances.
- In iOS the CameraStreamer constructor takes CALayer parameter (most commonly obtained via view.layer property).
- In Android the CameraStreamer constructor takes Surface parameter (most commonly obtained via TextureView::getSurfaceTexture() method).
- In Android take takeSnapshot() method is absent because the video decoder works directly with passed Surface object and therefore doesn't have access to raw frames. There is an easy and convenient way to take snapshot though: TextureView::getBitmap() method (the same view that holds the Surface from the previous step).
class CameraStreamer
CameraStreamer(Surface surface);
Constructs CameraStreamer instance.
release();
Android specific: releases unnecessary resources.
weak CameraStreamerDelegate delegate;
Indicates object which will receive and process callbacks.
StreamerItem currentItem;
Indicates the current item of the streamer.
CameraStreamerRenderMode renderMode;
Defines how the video is displayed within Surface bounds rect.
Bool muteAudio;
Indicates whether or not audio output of the player is muted. Only affects audio muting for the player instance and not for the device.
Float rate;
Indicates the desired rate of playback; 0.0 means "paused", 1.0 indicates a desire to play at the natural rate of the current item.
readonly CameraStreamerStatus status;
Indicates readiness of streamer to be used for playback.
readonly MobileSDKError failureReason;
If status is failed, this property describes the error that caused the failure.
readonly CameraStreamerPlaybackState playbackState;
Indicates whether playback is currently paused indefinitely, suspended while waiting for appropriate conditions, in progress or reached end of media data.
readonly CameraStreamerAudioStreamingState audioStreamingState;
Indicates whether audio streaming session is currently not streaming, being preraped for streaming or actually streaming.
readonly MobileSDKError audioNotStreamingReason;
If audioStreamingState becomes notStreaming unexpectedly (not as result of a -stopAudioStreaming method call), this property describes the reason.
readonly Double currentTime;
Returns the current time of the playback within [0 ... duration] range for footage stream or zero for live stream.
seekTo(Double time);
Moves the playback cursor within [0 ... duration] range.
stepBy(Int frameCount);
Pauses streamer and moves player's current item's current time forward or backward by the specified number of frames.
startAudioStreaming();
Starts audio streaming session.
stopAudioStreaming();
Stops audio streaming session.
takeSnapshot();
iOS specific: Generates a snapshot for a stream at current time.
protocol CameraStreamerDelegate
@optional onStatusChanged(CameraStreamerStatus newStatus);
Will get called when the status of streamer has been changed.
@optional onPlaybackStateChanged(CameraStreamerPlaybackState newState);
Will get called when the playback state of streamer has been changed.
@optional onAudioStreamingStateChanged(CameraStreamerAudioStreamingState newState);
Will get called when the audio streaming state of streaming has been changed.
@optional onCurrentItemStatusChanged(StreamerItemStatus newStatus);
Will get called when the status of current item has been changed.
@optional onCurrentItemDurationChanged(Double newDuration);
Will get called when the duration of current item has been changed.
@optional onSnapshotTaken(Byte[] snapshot, Double snapshotTime);
Will be called when snapshot has been generated.
enum CameraStreamerStatus
case unknown;
Indicates that the status of the streamer is not yet known because it has not tried to load new media resources for playback.
case readyToPlay;
Indicates that the streamer is ready to play StreamerItem instance.
case failed;
Indicates that the streamer can no longer play StreamerItem instance because of an error. The error is described by the value of the failureReason property.
enum CameraStreamerPlaybackState
case paused;
This state is entered 1) upon receipt of a -pause message or -setRate: message with a value of 0.0, 2) when a change in overall state requires playback to be halted, such as when an interruption occurs on iOS or 3) when the streamer has no item to play, i.e. when the receiver's currentItem is nil.
In this state, playback is paused indefinitely and will not resume until 1) a subsequent -play message is received or 2) a -setRate: message with a non-zero value for rate is received and sufficient media data has been buffered for playback to proceed.
case buffering;
This state is entered when 1) the playback buffer becomes empty and playback stalls in playing state, 2) when rate is set from zero to non-zero in paused state and insufficient media data has been buffered for playback to occur.
In this state, the value of the rate property is not currently effective but instead indicates the rate at which playback will start or resume.
case playing;
In this state, playback is currently progressing and rate changes will take effect immediately. Should playback stall because of insufficient media data, playbackState will change to buffering state.
case ended;
This state is entered when playback reaches end of media data. Subsequent -play: or setRate: with non-zero value messages will be ignored, -seekTo:, -stepBy:, -pause: or setRate: with zero value messages will change playbackState to paused state.
enum CameraStreamerAudioStreamingState
case notStreaming;
This state is entered 1) upon receipt of a -stopAudioStreaming message or 2) when a change in overall state or some other reason requires streaming to be halted.
case preparing;
This state is entered upon receipt of a -startAudioStreaming message if previous value is CMCameraStreamerAudioStreamingStateNotStreaming.
case streaming;
In this state, audio streming is currently progressing.
enum CameraStreamerRenderMode
case fillBounds;
Specifies that the video should be stretched to fill the layer’s bounds.
case aspectFit;
Specifies that the streamer should preserve the video’s aspect ratio and fit the video within the layer’s bounds.
case aspectFill;
Specifies that the streamer should preserve the video’s aspect ratio and fill the layer’s bounds.
class StreamerItem
static StreamerItem createItem(Long cameraId);
Initializes an instance StreamerItem with given cameraId.
static StreamerItem createItem(Long cameraId, Long recordingId);
Initializes an instance StreamerItem with given cameraId and recordingId.
readonly Long cameraId;
An id of camera for which live or footage stream should be played.
readonly Long recordingId;
An id of recording to be played.
readonly StreamerItemStatus status;
Indicates if the item is ready to be played.
readonly MobileSDKError failureReason;
If status is failed, this property describes the error that caused the failure.
readonly StreamerItemCapabilitiesMask capabilitiesMask;
Indicates playback capabilities of item.
readonly Double duration;
Indicates the duration of the item.
enum StreamerItemStatus
case unknown;
Indicates that the status of the streamer item is not yet known because it has not tried to load new media resources for playback.
case ready;
Indicates that the streamer item is ready to be played. At this moment metadata (capabilitiesMask, duration) can be processed.
case failed;
Indicates that the streamer item can no longer be played because of an error. The error is described by the value of the failureReason property.
enum StreamerItemCapabilitiesMask
case none = 0;
Indicates that item has no playback capabilities. Usually means that item represents live streaming.
case canSeek = 1 << 0;
Indicates whether the item suports seeking. Call CameraStreamer's -seekTo: method to seek stream to requested time.
case canSpeedPlay = 1 << 1;
Indicates whether the supports speed play. Rate can be changed by setting positive value to CameraStreamer's rate property.
case canStep = 1 << 2;
Indicates whether the item supports stepping. Call CameraStreamer's -stepBy: method to step by requested amount of frames.
case canStreamAudio = 1 << 3;
Indicates whether the item supports audio streaming. Audio streaming session can be managed by calling CMCameraStreamerInterface instance's -startAudioStreaming, -stopAudioStreaming methods.
DoorbellWizard (v3.1)
Hints:
- **iOS specific: DoorbellWizard's callback onPreparedForConnection returns nothing.**
- ****iOS specific:DoorbellWizard's method connectToCamera takes no parameters. User should connect to Wifi via Settings app, then return to app and call this method.
- **iOS specific:For iOS12 and higher you should add Access Wifi Information capability (Target Name - Capabilities) in order to use DoorbellWizard otherwise iOS would not grant SDK access to Wifi information.**
- ****Android specific: DoorbellWizard's callback onPreparedForConnection returns list of available Doorbell Wifi Networks.
- **Android specific: **DoorbellWizard's method connectToCamera takes WifiNetwork object (returned with onPreparedForConnection callback) as input parameter.
- **Android specific: **DoorbellWizard's has additional method disconnectFromDoorbellWifi.
class DoorbellWizard
DoorbellWizard(DoorbellWizardDelegate delegate);
Constructs DoorbellWizard instance.
prepareForConnection(Map<String, void *> options);
Prepares for connection process. Options map should contain "cameraId" (of disconnected camera) for restoration process or "zoneId" for adding process.
connectToCamera(WifiNetwork doorbellWifiNetwork);
Connects to wifi network of chosen Doorbell. For mode details about WifiNetwork class check NuboCamWizard page.
**iOS specific:** user should connect to Doorbell wifi network manually using Settings app. After returning to app he should call this method (without parameters).
Android specific: list of available wifi networks is returned by prepareForConnection callback. User should use one of returned object to pass as parameter of this function.
refreshWifiList();
Refreshes list of WifiNetwork objects to which Doorbell can be connected.
connectCameraToNetwork(WifiNetwork wifiNetwork, String cameraName);
Connects Doorbell to provided wifi network with given camera name.
cancelCurrentOperation();
Cancels current operation. No callbacks will be triggered.
disconnectFromDoorbellWifi();
Android specific: Disconnects device from Doorbell's Wi-Fi access point.
protocol DoorbellWizardDelegate
@required onPreparedForConnection(WifiNetwork[] doorbellWifiNetworks);
Called when SDK is ready for Doorbell connection.
Android specific: returns list of available Doorbell wifi networks to connect. One of objects should be used with connectToCamera method.
@required onConnectedToCamera();
Called when SDK established connection with Doorbell. Now user can retrieve list of wifi.
@optional onWifiListRefreshed(WifiNetwork[] networks);
Returns list of Wifi networks to which Doorbell can be connected.
@required onFinished(Long cameraId);
If everything went ok, will get called after the Doorbell has been added/restored.
@required onError(MobileSDKError error);
Will get called if there's an error in the process of adding/restoring Doorbell.
MobileSDKError (v3.1)
class MobileSDKError
MobileSDKErrorCode getCode();
Returns error code.
String getGeneralMessage();
Returns general message for error.
String getDetailMessage();
Returns detail message for error.
enum MobileSDKErrorCode
case internalError = 1;
An internal error has occurred.
case parsingError = 2;
The request could not be parsed correctly.
case validationError = 3;
The request was not valid according to semantic rules.
case resourceNotFound = 4;
A resource necessary to complete this request does not exist.
case duplicateResource = 5;
The new resource could not be created as a resource with the same identifying information already exists.
case businessRuleViolation = 6;
The request violated some business rule.
case subscriptionLimitsError = 7;
The request could not be carried out because of a subscription limit.
case authenticationError = 8;
Authentication failed while it is required for the request.
case authorisationError = 9;
You are not authorized for this request.
case unsupportedOperation = 10;
The request is not supported.
case deviceCapabiiltyNotSupported = 11;
The specific resource instance does not support the requested or required capability.
case deviceAuthorizationError = 12;
Can't carry out the request as the device reports the configured user credentials are incorrect.
case deviceInternalError = 13;
Can't carry out the request as device reported an error or responded in an unexpected way.
case deviceOfflineError = 14;
Can't carry out request as the device is offline.
case serverOfflineError = 15;
Can't reach server, request time outed.
Updated about 2 years ago