auto position videos which haven't been manually positioned
This commit is contained in:
parent
617dec72b9
commit
baa5439f0f
3 changed files with 57 additions and 38 deletions
|
@ -1933,7 +1933,6 @@ Metamaps.Realtime = {
|
||||||
chatOpen: false,
|
chatOpen: false,
|
||||||
status: true, // stores whether realtime is True/On or False/Off,
|
status: true, // stores whether realtime is True/On or False/Off,
|
||||||
broadcastingStatus: false,
|
broadcastingStatus: false,
|
||||||
videosInPosition: 1,
|
|
||||||
inConversation: false,
|
inConversation: false,
|
||||||
localVideo: null,
|
localVideo: null,
|
||||||
init: function () {
|
init: function () {
|
||||||
|
@ -2036,23 +2035,62 @@ Metamaps.Realtime = {
|
||||||
},
|
},
|
||||||
handleVideoAdded: function (v, id) {
|
handleVideoAdded: function (v, id) {
|
||||||
var self = Metamaps.Realtime;
|
var self = Metamaps.Realtime;
|
||||||
// random position for now
|
self.positionVideos();
|
||||||
var paddingAboveTop = 72;
|
|
||||||
var heightOfVideo = 150;
|
|
||||||
var padding = 25;
|
|
||||||
var top = paddingAboveTop + (self.videosInPosition * heightOfVideo) + padding;
|
|
||||||
var left = 30;
|
|
||||||
//var right = Math.floor((Math.random() * (468 - 100)) + 1);
|
|
||||||
v.setParent($('#wrapper'));
|
v.setParent($('#wrapper'));
|
||||||
$('#wrapper').append(v.$container);
|
|
||||||
v.$container.css({
|
|
||||||
top: top + 'px',
|
|
||||||
left: left + 'px'
|
|
||||||
});
|
|
||||||
v.$container.find('.video-cutoff').css({
|
v.$container.find('.video-cutoff').css({
|
||||||
border: '4px solid ' + self.mappersOnMap[id].color
|
border: '4px solid ' + self.mappersOnMap[id].color
|
||||||
});
|
});
|
||||||
self.videosInPosition += 1;
|
$('#wrapper').append(v.$container);
|
||||||
|
},
|
||||||
|
positionVideos: function () {
|
||||||
|
var self = Metamaps.Realtime;
|
||||||
|
var videoIds = Object.keys(self.room.videos);
|
||||||
|
var numOfVideos = videoIds.length;
|
||||||
|
var numOfVideosToPosition = _.filter(videoIds, function (id) {
|
||||||
|
return !self.room.videos[id].manuallyPositioned;
|
||||||
|
}).length;
|
||||||
|
|
||||||
|
var screenHeight = $(document).height();
|
||||||
|
var screenWidth = $(document).width();
|
||||||
|
var topExtraPadding = 20;
|
||||||
|
var topPadding = 30;
|
||||||
|
var leftPadding = 30;
|
||||||
|
var videoHeight = 150;
|
||||||
|
var videoWidth = 180;
|
||||||
|
var column = 0;
|
||||||
|
var row = 0;
|
||||||
|
var yFormula = function () {
|
||||||
|
var y = topExtraPadding + (topPadding + videoHeight)*row + topPadding;
|
||||||
|
if (y + videoHeight > screenHeight) {
|
||||||
|
row = 0;
|
||||||
|
column += 1;
|
||||||
|
y = yFormula();
|
||||||
|
}
|
||||||
|
row++;
|
||||||
|
return y;
|
||||||
|
};
|
||||||
|
var xFormula = function () {
|
||||||
|
var x = (leftPadding + videoWidth)*column + leftPadding;
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
|
||||||
|
// do self first
|
||||||
|
var myVideo = Metamaps.Realtime.localVideo.view;
|
||||||
|
if (!myVideo.manuallyPositioned) {
|
||||||
|
myVideo.$container.css({
|
||||||
|
top: yFormula() + 'px',
|
||||||
|
left: xFormula() + 'px'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
videoIds.forEach(function (id) {
|
||||||
|
var video = self.room.videos[id];
|
||||||
|
if (!video.manuallyPositioned) {
|
||||||
|
video.$container.css({
|
||||||
|
top: yFormula() + 'px',
|
||||||
|
left: xFormula() + 'px'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
},
|
},
|
||||||
startActiveMap: function () {
|
startActiveMap: function () {
|
||||||
var self = Metamaps.Realtime;
|
var self = Metamaps.Realtime;
|
||||||
|
@ -2083,7 +2121,6 @@ Metamaps.Realtime = {
|
||||||
self.room.leave();
|
self.room.leave();
|
||||||
self.room.chat.$container.hide();
|
self.room.chat.$container.hide();
|
||||||
self.room.chat.close();
|
self.room.chat.close();
|
||||||
self.videosInPosition = 1;
|
|
||||||
},
|
},
|
||||||
reenableRealtime: function() {
|
reenableRealtime: function() {
|
||||||
var confirmString = "The layout of your map has fallen out of sync with the saved copy. ";
|
var confirmString = "The layout of your map has fallen out of sync with the saved copy. ";
|
||||||
|
@ -2195,7 +2232,6 @@ Metamaps.Realtime = {
|
||||||
self.room.conversationEnding();
|
self.room.conversationEnding();
|
||||||
self.room.leaveVideoOnly();
|
self.room.leaveVideoOnly();
|
||||||
self.inConversation = false;
|
self.inConversation = false;
|
||||||
self.videosInPosition = 1;
|
|
||||||
self.localVideo.view.$container.hide().css({
|
self.localVideo.view.$container.hide().css({
|
||||||
top: '72px',
|
top: '72px',
|
||||||
left: '30px'
|
left: '30px'
|
||||||
|
@ -2303,6 +2339,8 @@ Metamaps.Realtime = {
|
||||||
self.webrtc.once('readyToCall', function () {
|
self.webrtc.once('readyToCall', function () {
|
||||||
self.videoInitialized = true;
|
self.videoInitialized = true;
|
||||||
self.readyToCall = true;
|
self.readyToCall = true;
|
||||||
|
self.localVideo.view.manuallyPositioned = false;
|
||||||
|
self.positionVideos();
|
||||||
self.localVideo.view.$container.show();
|
self.localVideo.view.$container.show();
|
||||||
if (self.localVideo && self.status) {
|
if (self.localVideo && self.status) {
|
||||||
$('#wrapper').append(self.localVideo.view.$container);
|
$('#wrapper').append(self.localVideo.view.$container);
|
||||||
|
@ -2329,7 +2367,6 @@ Metamaps.Realtime = {
|
||||||
self.room.chat.mapperLeftCall(Metamaps.Active.Mapper.id);
|
self.room.chat.mapperLeftCall(Metamaps.Active.Mapper.id);
|
||||||
self.room.leaveVideoOnly();
|
self.room.leaveVideoOnly();
|
||||||
self.inConversation = false;
|
self.inConversation = false;
|
||||||
self.videosInPosition = 1;
|
|
||||||
self.localVideo.view.$container.hide();
|
self.localVideo.view.$container.hide();
|
||||||
|
|
||||||
// if there's only two people in the room, and we're leaving
|
// if there's only two people in the room, and we're leaving
|
||||||
|
@ -4053,6 +4090,7 @@ Metamaps.Listeners = {
|
||||||
$(window).resize(function () {
|
$(window).resize(function () {
|
||||||
if (Metamaps.Visualize && Metamaps.Visualize.mGraph) Metamaps.Visualize.mGraph.canvas.resize($(window).width(), $(window).height());
|
if (Metamaps.Visualize && Metamaps.Visualize.mGraph) Metamaps.Visualize.mGraph.canvas.resize($(window).width(), $(window).height());
|
||||||
if ((Metamaps.Active.Map || Metamaps.Active.Topic) && Metamaps.Famous && Metamaps.Famous.maps.surf) Metamaps.Famous.maps.reposition();
|
if ((Metamaps.Active.Map || Metamaps.Active.Topic) && Metamaps.Famous && Metamaps.Famous.maps.surf) Metamaps.Famous.maps.reposition();
|
||||||
|
if (Metamaps.Active.Map && Metamaps.Realtime.inConversation) Metamaps.Realtime.positionVideos();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}; // end Metamaps.Listeners
|
}; // end Metamaps.Listeners
|
||||||
|
|
|
@ -141,8 +141,8 @@ Metamaps.Views.room = (function () {
|
||||||
var
|
var
|
||||||
v = new VideoView(video, null, id, false, { DOUBLE_CLICK_TOLERANCE: 200, avatar: peer.avatar, username: peer.username });
|
v = new VideoView(video, null, id, false, { DOUBLE_CLICK_TOLERANCE: 200, avatar: peer.avatar, username: peer.username });
|
||||||
|
|
||||||
if (this._videoAdded) this._videoAdded(v, peer.nick);
|
|
||||||
this.videos[peer.id] = v;
|
this.videos[peer.id] = v;
|
||||||
|
if (this._videoAdded) this._videoAdded(v, peer.nick);
|
||||||
}
|
}
|
||||||
|
|
||||||
room.prototype.removeVideo = function (peer) {
|
room.prototype.removeVideo = function (peer) {
|
||||||
|
|
|
@ -67,6 +67,7 @@ Metamaps.Views.videoView = (function () {
|
||||||
newY;
|
newY;
|
||||||
|
|
||||||
if (this.$parent && this.mouseIsDown) {
|
if (this.$parent && this.mouseIsDown) {
|
||||||
|
this.manuallyPositioned = true;
|
||||||
this.hasMoved = true;
|
this.hasMoved = true;
|
||||||
diffX = event.pageX - this.mouseMoveStart.x;
|
diffX = event.pageX - this.mouseMoveStart.x;
|
||||||
diffY = this.mouseMoveStart.y - event.pageY;
|
diffY = this.mouseMoveStart.y - event.pageY;
|
||||||
|
@ -94,14 +95,6 @@ Metamaps.Views.videoView = (function () {
|
||||||
}
|
}
|
||||||
$(document).trigger(videoView.events.videoControlClick, [this]);
|
$(document).trigger(videoView.events.videoControlClick, [this]);
|
||||||
},
|
},
|
||||||
/*yesReceiveClick: function () {
|
|
||||||
this.$receiveContainer.hide();
|
|
||||||
this.$avatar.hide();
|
|
||||||
$(this.video).prop('muted', false);
|
|
||||||
},
|
|
||||||
noReceiveClick: function () {
|
|
||||||
this.$container.hide();
|
|
||||||
}*/
|
|
||||||
};
|
};
|
||||||
|
|
||||||
var videoView = function(video, $parent, id, isMyself, config) {
|
var videoView = function(video, $parent, id, isMyself, config) {
|
||||||
|
@ -131,18 +124,6 @@ Metamaps.Views.videoView = (function () {
|
||||||
$vidContainer.addClass('video-cutoff');
|
$vidContainer.addClass('video-cutoff');
|
||||||
$vidContainer.append(this.video);
|
$vidContainer.append(this.video);
|
||||||
|
|
||||||
/*
|
|
||||||
if (!isMyself) {
|
|
||||||
this.$receiveContainer = $('<div class="video-receive"><div class="video-statement">' + config.username + ' is sharing their audio and video. Do you wish to receive it?</div><div class="btn-group"><button type="button" class="button btn-yes">Yes</button><button type="button" class="button btn-no">No</button></div></div>');
|
|
||||||
this.$container.append(this.$receiveContainer);
|
|
||||||
this.$container.find('.btn-yes').on('click', function (event) {
|
|
||||||
Handlers.yesReceiveClick.call(self, event);
|
|
||||||
});
|
|
||||||
this.$container.find('.btn-no').on('click', function (event) {
|
|
||||||
Handlers.noReceiveClick.call(self, event);
|
|
||||||
});
|
|
||||||
}*/
|
|
||||||
|
|
||||||
this.avatar = config.avatar;
|
this.avatar = config.avatar;
|
||||||
this.$avatar = $('<img draggable="false" class="collaborator-video-avatar" src="' + config.avatar + '" width="150" height="150" />');
|
this.$avatar = $('<img draggable="false" class="collaborator-video-avatar" src="' + config.avatar + '" width="150" height="150" />');
|
||||||
$vidContainer.append(this.$avatar);
|
$vidContainer.append(this.$avatar);
|
||||||
|
|
Loading…
Reference in a new issue