FS-8563 [verto_communicator] - Added callback to setAudioPlaybackDevice

This commit is contained in:
Jaon EarlWolf 2015-12-21 17:59:59 -03:00
parent 222eff143c
commit ef3e438406
4 changed files with 24 additions and 6 deletions

View File

@ -1679,6 +1679,11 @@ body:-webkit-full-screen #incall .video-footer {
animation: growY .2s reverse; animation: growY .2s reverse;
} }
.unsupported {
color: grey;
font-size: 10px;
}
@keyframes growY { @keyframes growY {
from { max-height:2000px;} from { max-height:2000px;}
to { max-height:0px;} to { max-height:0px;}

View File

@ -24,8 +24,13 @@
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="settings-microphone">Speaker:</label> <label for="settings-microphone">
<select name="microphone" id="settings-microphone" class="form-control" Speaker:
<span ng-show="!speakerFeature" class="unsupported">
Your browser doesn't seem to support this feature
</span>
</label>
<select name="microphone" id="settings-microphone" class="form-control" ng-disabled="!speakerFeature"
ng-model="mydata.selectedSpeaker" ng-options="item.id as item.label for item in verto.data.speakerDevices"> ng-model="mydata.selectedSpeaker" ng-options="item.id as item.label for item in verto.data.speakerDevices">
</select> </select>
</div> </div>

View File

@ -54,10 +54,9 @@
}); });
$rootScope.$on('changedSpeaker', function(event, speakerId) { $rootScope.$on('changedSpeaker', function(event, speakerId) {
// This should provide feedback if (verto.data.call) {
//setAudioPlaybackDevice(<id>[,<callback>[,<callback arg>]]); verto.data.call.setAudioPlaybackDevice(speakerId, sinkIdCallback);
// if callback is set it will be called as callback(<bool success/fail>, <device name>, <arg if you supplied it>) }
verto.data.call.setAudioPlaybackDevice(speakerId);
}); });
/** /**
@ -527,6 +526,13 @@
}); });
}; };
function sinkIdCallback(success, deviceName) {
if (success) {
toastr.info('Speaker is now <span class="install">' + deviceName + '</a>', 'Success', { allowHtml: true });
} else {
toastr.error('Your browser doesn\'t seem to support this feature', 'Error');
}
}
} }
); );

View File

@ -12,6 +12,8 @@
$scope.verto = verto; $scope.verto = verto;
$scope.mydata = angular.copy(storage.data); $scope.mydata = angular.copy(storage.data);
$scope.speakerFeature = typeof document.getElementById('webcam').sinkId !== 'undefined';
$scope.ok = function() { $scope.ok = function() {
if ($scope.mydata.selectedSpeaker != storage.data.selectedSpeaker) { if ($scope.mydata.selectedSpeaker != storage.data.selectedSpeaker) {
$rootScope.$emit('changedSpeaker', $scope.mydata.selectedSpeaker); $rootScope.$emit('changedSpeaker', $scope.mydata.selectedSpeaker);