59 lines
1.8 KiB
JavaScript
59 lines
1.8 KiB
JavaScript
////These lines should be uncommented when require works in app.js
|
|
var RTCBrowserType = require("../../service/RTC/RTCBrowserType.js");
|
|
var MediaStreamType = require("../../service/RTC/MediaStreamTypes");
|
|
|
|
/**
|
|
* Creates a MediaStream object for the given data, session id and ssrc.
|
|
* It is a wrapper class for the MediaStream.
|
|
*
|
|
* @param data the data object from which we obtain the stream,
|
|
* the peerjid, etc.
|
|
* @param sid the session id
|
|
* @param ssrc the ssrc corresponding to this MediaStream
|
|
*
|
|
* @constructor
|
|
*/
|
|
function MediaStream(data, sid, ssrc, browser) {
|
|
|
|
// XXX(gp) to minimize headaches in the future, we should build our
|
|
// abstractions around tracks and not streams. ORTC is track based API.
|
|
// Mozilla expects m-lines to represent media tracks.
|
|
//
|
|
// Practically, what I'm saying is that we should have a MediaTrack class
|
|
// and not a MediaStream class.
|
|
//
|
|
// Also, we should be able to associate multiple SSRCs with a MediaTrack as
|
|
// a track might have an associated RTX and FEC sources.
|
|
|
|
this.sid = sid;
|
|
this.stream = data.stream;
|
|
this.peerjid = data.peerjid;
|
|
this.ssrc = ssrc;
|
|
this.type = (this.stream.getVideoTracks().length > 0)?
|
|
MediaStreamType.VIDEO_TYPE : MediaStreamType.AUDIO_TYPE;
|
|
this.videoType = null;
|
|
this.muted = false;
|
|
if(browser == RTCBrowserType.RTC_BROWSER_FIREFOX)
|
|
{
|
|
if (!this.getVideoTracks)
|
|
this.getVideoTracks = function () { return []; };
|
|
if (!this.getAudioTracks)
|
|
this.getAudioTracks = function () { return []; };
|
|
}
|
|
}
|
|
|
|
|
|
MediaStream.prototype.getOriginalStream = function()
|
|
{
|
|
return this.stream;
|
|
}
|
|
|
|
MediaStream.prototype.setMute = function (value)
|
|
{
|
|
this.stream.muted = value;
|
|
this.muted = value;
|
|
}
|
|
|
|
|
|
module.exports = MediaStream;
|