The top level iosrtc
module is a JavaScript Object containing all the WebRTC classes and functions.
The iosrtc
module is exposed within the window.cordova.plugins
namespace (Cordova plugins convention). Example:
var pc = new cordova.plugins.iosrtc.RTCPeerConnection({
iceServers: []
});
cordova.plugins.iosrtc.getUserMedia(
// constraints
{ audio: true, video: true },
// success callback
function (stream) {
console.log('got local MediaStream: ', stream);
pc.addStream(stream);
},
// failure callback
function (error) {
console.error('getUserMedia failed: ', error);
}
);
Implementation of the getUserMedia()
function as specified by the W3C Media Capture and Streams draft.
The function allows both the old/deprecated callbacks based syntax and the new one based on Promises (depending on the number and type of the given arguments).
NOTE: In iOS devices there is a single audio input (mic) and two video inputs (camera). If the given constraints include "video" the device chosen by default is the front camera. However the back camera can be chosen by passing an "optional" or "mandatory" constraint to the function:
cordova.plugins.iosrtc.getUserMedia({
audio: true,
video: {
optional: [
{ sourceId: 'com.apple.avfoundation.avcapturedevice.built-in_video:1' }
]
}
});
NOTE: The API to select a specific device is outdated, but it matches the one currently implemented by Chrome browser.
TODO:
- Rich constraints.
Implementation of the enumerateDevices()
function as specified in the W3C Media Capture and Streams draft.
The function allows both the old/deprecated callbacks based syntax and the new one based on Promises.
The success callback is called with a list of MediaDeviceInfo
objects as defined in the same spec. However such an object includes deprecated fields for backwards compatibility. The read-only fields in a MediaDeviceInfo
object are:
deviceId
(String)kind
(String)label
(String)groupId
(always an empty string)id
(same asdeviceId
, deprecated)facing
(always an empty string, deprecated)
NOTE: The deviceId
or id
field is the value to be used in the sourceId
field of getUserMedia()
above to choose a specific device.
Exposes the RTCPeerConnection
class as defined by the W3C Real-time Communication Between Browsers draft.
All the methods are implemented in both fashions: the deprecated callbacks based syntax and the new one based on Promises.
TODO:
updateIce()
method.getStats()
method.- Can not use
id
value greater than 1023 in the config object forcreateDataChannel()
(see issue #4618).
Exposes the RTCSessionDescription
class as defined by the spec.
Exposes the RTCIceCandidate
class as defined by the spec.
Exposes the MediaStreamTrack
class as defined by the spec.
NOTE: The only reason to make this class public is to expose the deprecated MediaStreamTrack.getSources()
class function, which is an "alias" to the getMediaDevices()
function described above.
TODO:
muted
attribute (not exposed by the Objective-C wrapper of the Google WebRTC library).onmute
andonunmute
events.clone()
methods.getCapabilities()
method.getConstraints()
method.getSettings()
method.applyConstraints()
method.onoverconstrained
event.
When calling this method, the height/width, opacity, visibility and z-index of all the HTML5 video elements rendering a MediaStream
are recomputed and the iOS native UIView
layer updated according.
Call this method when the position or size of a video element changes.
By calling this method the JavaScript global namespace gets "polluted" with the following additions:
navigator.getUserMedia
navigator.mediaDevices.getUserMedia
navigator.mediaDevices.enumerateDevices
window.RTCPeerConnection
window.RTCSessionDescription
window.RTCIceCandidate
window.MediaStreamTrack
Useful to avoid iOS specified code in your HTML5 application.
The debug module. Useful to enable verbose logging:
cordova.plugins.iosrtc.debug.enable('iosrtc*');
A plugin interface for rtcninja.
Usage (assuming that Cordova Device Plugin is installed):
// Just for Cordova apps.
document.addEventListener('deviceready', function () {
// Just for iOS devices.
if (window.device.platform === 'iOS') {
// Load rtcninja with cordova-plugin-iosrtc.
rtcninja({
plugin: cordova.plugins.iosrtc.rtcninjaPlugin
});
}
console.log('WebRTC supported?: %s', rtcninja.hasWebRTC());
// => WebRTC supported?: true
rtcninja.RTCPeerConnection === cordova.plugins.iosrtc.RTCPeerConnection;
// => true
});
The MediaStream
class (as defined in the spec) is not directly exposed by iosrtc
via public API. Instead an instance of MediaStream
is given within onaddstream
/ onremovestream
events or the success callback of getUserMedia()
.
NOTES:
stop()
method implemented for backwards compatibility (it callsstop()
on all itsMediaStreamTracks
).
TODO:
clone()
method.- No
onaddtrack
/onremovetrack
events due to a limitation in the Objective-C wrapper (see issue #4640).
The RTCDataChannel
class (as defined in the spec) is not directly exposed by iosrtc
via public API. Instead an instance of RTCDataChannel
is returned by createDataChannel()
and provided by the ondatachannel
event.
The full DataChannel API is implemented (including binary messages).
TODO:
binaryType
just acceptsarraybuffer
(same as Chrome browser).- Cannot read the
protocol
property of aRTCDataChannel
(see issue #4614).