Fixes issues for audio only participants

This commit is contained in:
hristoterezov 2016-01-29 13:31:58 -06:00
parent 4e66aefa26
commit 1176390214
3 changed files with 19 additions and 9 deletions

View File

@ -225,7 +225,9 @@ export default {
return JitsiMeetJS.init(config).then(() => { return JitsiMeetJS.init(config).then(() => {
return Promise.all([ return Promise.all([
this.createLocalTracks('audio', 'video').catch( this.createLocalTracks('audio', 'video').catch(()=>{
return this.createLocalTracks('audio');
}).catch(
() => {return [];}), () => {return [];}),
connect() connect()
]); ]);
@ -500,7 +502,7 @@ export default {
handler(id , mute); handler(id , mute);
}); });
room.on(ConferenceEvents.TRACK_AUDIO_LEVEL_CHANGED, (id, lvl) => { room.on(ConferenceEvents.TRACK_AUDIO_LEVEL_CHANGED, (id, lvl) => {
if(this.isLocalId(id) && localAudio.isMuted()) { if(this.isLocalId(id) && localAudio && localAudio.isMuted()) {
lvl = 0; lvl = 0;
} }
@ -584,9 +586,13 @@ export default {
}); });
APP.UI.addListener(UIEvents.AUDIO_MUTED, (muted) => { APP.UI.addListener(UIEvents.AUDIO_MUTED, (muted) => {
if(!localAudio)
return;
(muted)? localAudio.mute() : localAudio.unmute(); (muted)? localAudio.mute() : localAudio.unmute();
}); });
APP.UI.addListener(UIEvents.VIDEO_MUTED, (muted) => { APP.UI.addListener(UIEvents.VIDEO_MUTED, (muted) => {
if(!localVideo)
return;
(muted)? localVideo.mute() : localVideo.unmute(); (muted)? localVideo.mute() : localVideo.unmute();
}); });
@ -794,7 +800,7 @@ export default {
APP.desktopsharing.addListener(DSEvents.NEW_STREAM_CREATED, APP.desktopsharing.addListener(DSEvents.NEW_STREAM_CREATED,
(track, callback) => { (track, callback) => {
const localCallback = (newTrack) => { const localCallback = (newTrack) => {
if(!newTrack || !newTrack.isLocal() || if(!newTrack || !localVideo || !newTrack.isLocal() ||
newTrack !== localVideo) newTrack !== localVideo)
return; return;
if(localVideo.isMuted() && if(localVideo.isMuted() &&
@ -808,7 +814,8 @@ export default {
if(room) { if(room) {
room.on(ConferenceEvents.TRACK_ADDED, localCallback); room.on(ConferenceEvents.TRACK_ADDED, localCallback);
} }
localVideo.stop(); if(localVideo)
localVideo.stop();
localVideo = track; localVideo = track;
addTrack(track); addTrack(track);
if(!room) if(!room)

View File

@ -277,6 +277,9 @@ class VideoContainer extends LargeContainer {
this.stream = stream; this.stream = stream;
this.videoType = videoType; this.videoType = videoType;
if(!stream)
return;
stream.attach(this.$video); stream.attach(this.$video);
let flipX = stream.isLocal() && !this.isScreenSharing(); let flipX = stream.isLocal() && !this.isScreenSharing();
@ -421,7 +424,7 @@ export default class LargeVideoManager {
// change the avatar url on large // change the avatar url on large
this.updateAvatar(Avatar.getAvatarUrl(id)); this.updateAvatar(Avatar.getAvatarUrl(id));
let isVideoMuted = stream.isMuted(); let isVideoMuted = stream? stream.isMuted() : true;
// show the avatar on large if needed // show the avatar on large if needed
this.videoContainer.showAvatar(isVideoMuted); this.videoContainer.showAvatar(isVideoMuted);
@ -443,19 +446,18 @@ export default class LargeVideoManager {
/** /**
* Update large video. * Update large video.
* Switches to large video even if previously other container was visible. * Switches to large video even if previously other container was visible.
* @param userID the userID of the participant associated with the stream
* @param {JitsiTrack?} stream new stream * @param {JitsiTrack?} stream new stream
* @param {string?} videoType new video type * @param {string?} videoType new video type
* @returns {Promise} * @returns {Promise}
*/ */
updateLargeVideo (stream, videoType) { updateLargeVideo (userID, stream, videoType) {
let id = getStreamOwnerId(stream);
if (this.newStreamData) { if (this.newStreamData) {
this.newStreamData.reject(); this.newStreamData.reject();
} }
this.newStreamData = createDeferred(); this.newStreamData = createDeferred();
this.newStreamData.id = id; this.newStreamData.id = userID;
this.newStreamData.stream = stream; this.newStreamData.stream = stream;
this.newStreamData.videoType = videoType; this.newStreamData.videoType = videoType;

View File

@ -987,6 +987,7 @@ var VideoLayout = {
let videoType = this.getRemoteVideoType(id); let videoType = this.getRemoteVideoType(id);
largeVideo.updateLargeVideo( largeVideo.updateLargeVideo(
id,
smallVideo.videoStream, smallVideo.videoStream,
videoType videoType
).then(function() { ).then(function() {