jiti-meet/modules/RTC/MediaStream.js

61 lines
1.8 KiB
JavaScript
Raw Normal View History

2014-12-19 13:59:08 +00:00
////These lines should be uncommented when require works in app.js
var MediaStreamType = require("../../service/RTC/MediaStreamTypes");
var StreamEventType = require("../../service/RTC/StreamEventTypes");
2014-12-19 13:59:08 +00:00
/**
* 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, eventEmitter) {
// 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.
2014-12-19 13:59:08 +00:00
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;
2014-12-19 13:59:08 +00:00
this.muted = false;
this.eventEmitter = eventEmitter;
2014-12-19 13:59:08 +00:00
}
MediaStream.prototype.getOriginalStream = function()
{
return this.stream;
};
2014-12-19 13:59:08 +00:00
MediaStream.prototype.setMute = function (value)
{
this.stream.muted = value;
this.muted = value;
};
MediaStream.prototype.setVideoType = function (value) {
if(this.videoType === value)
return;
this.videoType = value;
this.eventEmitter.emit(StreamEventType.EVENT_TYPE_REMOTE_CHANGED,
this.peerjid);
};
2014-12-19 13:59:08 +00:00
module.exports = MediaStream;