mirror of
https://github.com/overte-org/overte.git
synced 2025-04-26 12:56:16 +02:00
93 lines
3.9 KiB
JavaScript
93 lines
3.9 KiB
JavaScript
//
|
|
// createGlobalEventBridge.js
|
|
//
|
|
// Created by Anthony J. Thibault on 9/7/2016
|
|
// Copyright 2016 High Fidelity, Inc.
|
|
//
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
|
|
// Stick a EventBridge object in the global namespace.
|
|
var EventBridge;
|
|
(function () {
|
|
// the TempEventBridge class queues up emitWebEvent messages and executes them when the real EventBridge is ready.
|
|
// Similarly, it holds all scriptEventReceived callbacks, and hooks them up to the real EventBridge.
|
|
function TempEventBridge() {
|
|
var self = this;
|
|
this._callbacks = [];
|
|
this._messages = [];
|
|
this.scriptEventReceived = {
|
|
connect: function (callback) {
|
|
self._callbacks.push(callback);
|
|
}
|
|
};
|
|
this.emitWebEvent = function (message) {
|
|
self._messages.push(message);
|
|
};
|
|
};
|
|
|
|
EventBridge = new TempEventBridge();
|
|
|
|
var webChannel = new QWebChannel(qt.webChannelTransport, function (channel) {
|
|
// replace the TempEventBridge with the real one.
|
|
var tempEventBridge = EventBridge;
|
|
EventBridge = channel.objects.eventBridge;
|
|
EventBridge.audioOutputDeviceChanged.connect(function(deviceName) {
|
|
navigator.mediaDevices.getUserMedia({ audio: true, video: false }).then(function(mediaStream) {
|
|
navigator.mediaDevices.enumerateDevices().then(function(devices) {
|
|
devices.forEach(function(device) {
|
|
if (device.kind == "audiooutput") {
|
|
if (device.label == deviceName){
|
|
console.log("Changing HTML audio output to device " + device.label);
|
|
var deviceId = device.deviceId;
|
|
var videos = document.getElementsByTagName("video");
|
|
for (var i = 0; i < videos.length; i++){
|
|
videos[i].setSinkId(deviceId);
|
|
}
|
|
var audios = document.getElementsByTagName("audio");
|
|
for (var i = 0; i < audios.length; i++){
|
|
audios[i].setSinkId(deviceId);
|
|
}
|
|
}
|
|
}
|
|
});
|
|
|
|
}).catch(function(err) {
|
|
console.log("Error getting media devices"+ err.name + ": " + err.message);
|
|
});
|
|
}).catch(function(err) {
|
|
console.log("Error getting user media"+ err.name + ": " + err.message);
|
|
});
|
|
});
|
|
|
|
// To be able to update the state of the output device selection for every element added to the DOM
|
|
// we need to listen to events that might precede the addition of this elements.
|
|
// A more robust hack will be to add a setInterval that look for DOM changes every 100-300 ms (low performance?)
|
|
|
|
window.addEventListener("load",function(event) {
|
|
setTimeout(function() {
|
|
EventBridge.forceHtmlAudioOutputDeviceUpdate();
|
|
}, 1200);
|
|
}, false);
|
|
|
|
document.addEventListener("click",function(){
|
|
setTimeout(function() {
|
|
EventBridge.forceHtmlAudioOutputDeviceUpdate();
|
|
}, 1200);
|
|
}, false);
|
|
|
|
document.addEventListener("change",function(){
|
|
setTimeout(function() {
|
|
EventBridge.forceHtmlAudioOutputDeviceUpdate();
|
|
}, 1200);
|
|
}, false);
|
|
|
|
tempEventBridge._callbacks.forEach(function (callback) {
|
|
EventBridge.scriptEventReceived.connect(callback);
|
|
});
|
|
tempEventBridge._messages.forEach(function (message) {
|
|
EventBridge.emitWebEvent(message);
|
|
});
|
|
});
|
|
})();
|