1 Star 0 Fork 56

jinzhexian / vr-stream-web-player

forked from lhbxxx / vr-stream-web-player 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
'derequire 57.58 KB
一键复制 编辑 原始数据 按行查看 历史
jinzhexian 提交于 2020-09-07 10:47 . VR 调试
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.WebVRManager = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
/*
* Copyright 2015 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var Emitter = require('./emitter.js');
var Modes = require('./modes.js');
var Util = require('./util.js');
/**
* Everything having to do with the WebVR button.
* Emits a 'click' event when it's clicked.
*/
function ButtonManager(opt_root) {
var root = opt_root || document.body;
this.loadIcons_();
// Make the fullscreen button.
var fsButton = this.createButton();
fsButton.src = this.ICONS.fullscreen;
fsButton.title = 'Fullscreen mode';
var s = fsButton.style;
s.bottom = 0;
s.right = 0;
fsButton.addEventListener('click', this.createClickHandler_('fs'));
root.appendChild(fsButton);
this.fsButton = fsButton;
// Make the VR button.
var vrButton = this.createButton();
vrButton.src = this.ICONS.cardboard;
vrButton.title = 'Virtual reality mode';
var s = vrButton.style;
s.bottom = 0;
s.right = '48px';
vrButton.addEventListener('click', this.createClickHandler_('vr'));
root.appendChild(vrButton);
this.vrButton = vrButton;
this.isVisible = true;
}
ButtonManager.prototype = new Emitter();
ButtonManager.prototype.createButton = function() {
var button = document.createElement('img');
button.className = 'webvr-button';
var s = button.style;
s.position = 'absolute';
s.width = '24px'
s.height = '24px';
s.backgroundSize = 'cover';
s.backgroundColor = 'transparent';
s.border = 0;
s.userSelect = 'none';
s.webkitUserSelect = 'none';
s.MozUserSelect = 'none';
s.cursor = 'pointer';
s.padding = '12px';
s.zIndex = 1;
s.display = 'none';
s.boxSizing = 'content-box';
// Prevent button from being selected and dragged.
button.draggable = false;
button.addEventListener('dragstart', function(e) {
e.preventDefault();
});
// Style it on hover.
button.addEventListener('mouseenter', function(e) {
s.filter = s.webkitFilter = 'drop-shadow(0 0 5px rgba(255,255,255,1))';
});
button.addEventListener('mouseleave', function(e) {
s.filter = s.webkitFilter = '';
});
return button;
};
ButtonManager.prototype.setMode = function(mode, isVRCompatible) {
isVRCompatible = isVRCompatible || WebVRConfig.FORCE_ENABLE_VR;
if (!this.isVisible) {
return;
}
switch (mode) {
case Modes.NORMAL:
this.fsButton.style.display = 'block';
this.fsButton.src = this.ICONS.fullscreen;
this.vrButton.style.display = (isVRCompatible ? 'block' : 'none');
break;
case Modes.MAGIC_WINDOW:
this.fsButton.style.display = 'block';
this.fsButton.src = this.ICONS.exitFullscreen;
this.vrButton.style.display = 'none';
break;
case Modes.VR:
this.fsButton.style.display = 'none';
this.vrButton.style.display = 'none';
break;
}
// Hack for Safari Mac/iOS to force relayout (svg-specific issue)
// http://goo.gl/hjgR6r
var oldValue = this.fsButton.style.display;
this.fsButton.style.display = 'inline-block';
this.fsButton.offsetHeight;
this.fsButton.style.display = oldValue;
};
ButtonManager.prototype.setVisibility = function(isVisible) {
this.isVisible = isVisible;
this.fsButton.style.display = isVisible ? 'block' : 'none';
this.vrButton.style.display = isVisible ? 'block' : 'none';
};
ButtonManager.prototype.createClickHandler_ = function(eventName) {
return function(e) {
e.stopPropagation();
e.preventDefault();
this.emit(eventName);
}.bind(this);
};
ButtonManager.prototype.loadIcons_ = function() {
// Preload some hard-coded SVG.
this.ICONS = {};
this.ICONS.cardboard = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMjAuNzQgNkgzLjIxQzIuNTUgNiAyIDYuNTcgMiA3LjI4djEwLjQ0YzAgLjcuNTUgMS4yOCAxLjIzIDEuMjhoNC43OWMuNTIgMCAuOTYtLjMzIDEuMTQtLjc5bDEuNC0zLjQ4Yy4yMy0uNTkuNzktMS4wMSAxLjQ0LTEuMDFzMS4yMS40MiAxLjQ1IDEuMDFsMS4zOSAzLjQ4Yy4xOS40Ni42My43OSAxLjExLjc5aDQuNzljLjcxIDAgMS4yNi0uNTcgMS4yNi0xLjI4VjcuMjhjMC0uNy0uNTUtMS4yOC0xLjI2LTEuMjh6TTcuNSAxNC42MmMtMS4xNyAwLTIuMTMtLjk1LTIuMTMtMi4xMiAwLTEuMTcuOTYtMi4xMyAyLjEzLTIuMTMgMS4xOCAwIDIuMTIuOTYgMi4xMiAyLjEzcy0uOTUgMi4xMi0yLjEyIDIuMTJ6bTkgMGMtMS4xNyAwLTIuMTMtLjk1LTIuMTMtMi4xMiAwLTEuMTcuOTYtMi4xMyAyLjEzLTIuMTNzMi4xMi45NiAyLjEyIDIuMTMtLjk1IDIuMTItMi4xMiAyLjEyeiIvPgogICAgPHBhdGggZmlsbD0ibm9uZSIgZD0iTTAgMGgyNHYyNEgwVjB6Ii8+Cjwvc3ZnPgo=');
this.ICONS.fullscreen = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNNyAxNEg1djVoNXYtMkg3di0zem0tMi00aDJWN2gzVjVINXY1em0xMiA3aC0zdjJoNXYtNWgtMnYzek0xNCA1djJoM3YzaDJWNWgtNXoiLz4KPC9zdmc+Cg==');
this.ICONS.exitFullscreen = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNNSAxNmgzdjNoMnYtNUg1djJ6bTMtOEg1djJoNVY1SDh2M3ptNiAxMWgydi0zaDN2LTJoLTV2NXptMi0xMVY1aC0ydjVoNVY4aC0zeiIvPgo8L3N2Zz4K');
this.ICONS.settings = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMy0uNjEtLjIybC0yLjQ5IDFjLS41Mi0uNC0xLjA4LS43My0xLjY5LS45OGwtLjM4LTIuNjVDMTQuNDYgMi4xOCAxNC4yNSAyIDE0IDJoLTRjLS4yNSAwLS40Ni4xOC0uNDkuNDJsLS4zOCAyLjY1Yy0uNjEuMjUtMS4xNy41OS0xLjY5Ljk4bC0yLjQ5LTFjLS4yMy0uMDktLjQ5IDAtLjYxLjIybC0yIDMuNDZjLS4xMy4yMi0uMDcuNDkuMTIuNjRsMi4xMSAxLjY1Yy0uMDQuMzItLjA3LjY1LS4wNy45OHMuMDMuNjYuMDcuOThsLTIuMTEgMS42NWMtLjE5LjE1LS4yNC40Mi0uMTIuNjRsMiAzLjQ2Yy4xMi4yMi4zOS4zLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjAzLjI0LjI0LjQyLjQ5LjQyaDRjLjI1IDAgLjQ2LS4xOC40OS0uNDJsLjM4LTIuNjVjLjYxLS4yNSAxLjE3LS41OSAxLjY5LS45OGwyLjQ5IDFjLjIzLjA5LjQ5IDAgLjYxLS4yMmwyLTMuNDZjLjEyLS4yMi4wNy0uNDktLjEyLS42NGwtMi4xMS0xLjY1ek0xMiAxNS41Yy0xLjkzIDAtMy41LTEuNTctMy41LTMuNXMxLjU3LTMuNSAzLjUtMy41IDMuNSAxLjU3IDMuNSAzLjUtMS41NyAzLjUtMy41IDMuNXoiLz4KPC9zdmc+Cg==');
};
module.exports = ButtonManager;
},{"./emitter.js":2,"./modes.js":3,"./util.js":4}],2:[function(require,module,exports){
/*
* Copyright 2015 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function Emitter() {
this.callbacks = {};
}
Emitter.prototype.emit = function(eventName) {
var callbacks = this.callbacks[eventName];
if (!callbacks) {
//console.log('No valid callback specified.');
return;
}
var args = [].slice.call(arguments);
// Eliminate the first param (the callback).
args.shift();
for (var i = 0; i < callbacks.length; i++) {
callbacks[i].apply(this, args);
}
};
Emitter.prototype.on = function(eventName, callback) {
if (eventName in this.callbacks) {
this.callbacks[eventName].push(callback);
} else {
this.callbacks[eventName] = [callback];
}
};
module.exports = Emitter;
},{}],3:[function(require,module,exports){
/*
* Copyright 2015 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var Modes = {
UNKNOWN: 0,
// Not fullscreen, just tracking.
NORMAL: 1,
// Magic window immersive mode.
MAGIC_WINDOW: 2,
// Full screen split screen VR mode.
VR: 3,
};
module.exports = Modes;
},{}],4:[function(require,module,exports){
/*
* Copyright 2015 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var Util = {};
Util.base64 = function(mimeType, base64) {
return 'data:' + mimeType + ';base64,' + base64;
};
Util.isMobile = function() {
var check = false;
(function(a){if(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0,4)))check = true})(navigator.userAgent||navigator.vendor||window.opera);
return check;
};
Util.isFirefox = function() {
return /firefox/i.test(navigator.userAgent);
};
Util.isIOS = function() {
return /(iPad|iPhone|iPod)/g.test(navigator.userAgent);
};
Util.isIFrame = function() {
try {
return window.self !== window.top;
} catch (e) {
return true;
}
};
Util.appendQueryParameter = function(url, key, value) {
// Determine delimiter based on if the URL already GET parameters in it.
var delimiter = (url.indexOf('?') < 0 ? '?' : '&');
url += delimiter + key + '=' + value;
return url;
};
// From http://goo.gl/4WX3tg
Util.getQueryParameter = function(name) {
var name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"),
results = regex.exec(location.search);
return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
};
Util.isLandscapeMode = function() {
return (window.orientation == 90 || window.orientation == -90);
};
Util.getScreenWidth = function() {
return Math.max(window.screen.width, window.screen.height) *
window.devicePixelRatio;
};
Util.getScreenHeight = function() {
return Math.min(window.screen.width, window.screen.height) *
window.devicePixelRatio;
};
module.exports = Util;
},{}],5:[function(require,module,exports){
/*
* Copyright 2015 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var ButtonManager = require('./button-manager.js');
var Emitter = require('./emitter.js');
var Modes = require('./modes.js');
var Util = require('./util.js');
/**
* Helper for getting in and out of VR mode.
*/
function WebVRManager(renderer, effect, params) {
this.params = params || {};
this.mode = Modes.UNKNOWN;
// Set option to hide the button.
this.hideButton = this.params.hideButton || false;
// Whether or not the FOV should be distorted or un-distorted. By default, it
// should be distorted, but in the case of vertex shader based distortion,
// ensure that we use undistorted parameters.
this.predistorted = !!this.params.predistorted;
// Save the THREE.js renderer and effect for later.
this.renderer = renderer;
this.effect = effect;
var polyfillWrapper = document.querySelector('.webvr-polyfill-fullscreen-wrapper');
this.button = new ButtonManager(polyfillWrapper);
this.isFullscreenDisabled = !!Util.getQueryParameter('no_fullscreen');
this.startMode = Modes.NORMAL;
var startModeParam = parseInt(Util.getQueryParameter('start_mode'));
if (!isNaN(startModeParam)) {
this.startMode = startModeParam;
}
if (this.hideButton) {
this.button.setVisibility(false);
}
// Check if the browser is compatible with WebVR.
this.getDeviceByType_(VRDisplay).then(function(hmd) {
this.hmd = hmd;
// Only enable VR mode if there's a VR device attached or we are running the
// polyfill on mobile.
if (!this.isVRCompatibleOverride) {
this.isVRCompatible = !hmd.isPolyfilled || Util.isMobile();
}
switch (this.startMode) {
case Modes.MAGIC_WINDOW:
this.setMode_(Modes.MAGIC_WINDOW);
break;
case Modes.VR:
this.enterVRMode_();
this.setMode_(Modes.VR);
break;
default:
this.setMode_(Modes.NORMAL);
}
this.emit('initialized');
}.bind(this));
// Hook up button listeners.
this.button.on('fs', this.onFSClick_.bind(this));
this.button.on('vr', this.onVRClick_.bind(this));
// Bind to fullscreen events.
document.addEventListener('webkitfullscreenchange',
this.onFullscreenChange_.bind(this));
document.addEventListener('mozfullscreenchange',
this.onFullscreenChange_.bind(this));
document.addEventListener('msfullscreenchange',
this.onFullscreenChange_.bind(this));
// Bind to VR* specific events.
window.addEventListener('vrdisplaypresentchange',
this.onVRDisplayPresentChange_.bind(this));
window.addEventListener('vrdisplaydeviceparamschange',
this.onVRDisplayDeviceParamsChange_.bind(this));
}
WebVRManager.prototype = new Emitter();
// Expose these values externally.
WebVRManager.Modes = Modes;
WebVRManager.prototype.render = function(scene, camera, timestamp) {
// Scene may be an array of two scenes, one for each eye.
if (scene instanceof Array) {
this.effect.render(scene[0], camera);
} else {
this.effect.render(scene, camera);
}
};
WebVRManager.prototype.setVRCompatibleOverride = function(isVRCompatible) {
this.isVRCompatible = isVRCompatible;
this.isVRCompatibleOverride = true;
// Don't actually change modes, just update the buttons.
this.button.setMode(this.mode, this.isVRCompatible);
};
WebVRManager.prototype.setFullscreenCallback = function(callback) {
this.fullscreenCallback = callback;
};
WebVRManager.prototype.setVRCallback = function(callback) {
this.vrCallback = callback;
};
WebVRManager.prototype.setExitFullscreenCallback = function(callback) {
this.exitFullscreenCallback = callback;
}
/**
* Promise returns true if there is at least one HMD device available.
*/
WebVRManager.prototype.getDeviceByType_ = function(type) {
return new Promise(function(resolve, reject) {
navigator.getVRDisplays().then(function(displays) {
// Promise succeeds, but check if there are any displays actually.
for (var i = 0; i < displays.length; i++) {
if (displays[i] instanceof type) {
resolve(displays[i]);
break;
}
}
resolve(null);
}, function() {
// No displays are found.
resolve(null);
});
});
};
/**
* Helper for entering VR mode.
*/
WebVRManager.prototype.enterVRMode_ = function() {
this.hmd.requestPresent([{
source: this.renderer.domElement,
predistorted: this.predistorted
}]);
};
WebVRManager.prototype.setMode_ = function(mode) {
var oldMode = this.mode;
if (mode == this.mode) {
console.warn('Not changing modes, already in %s', mode);
return;
}
// console.log('Mode change: %s => %s', this.mode, mode);
this.mode = mode;
this.button.setMode(mode, this.isVRCompatible);
// Emit an event indicating the mode changed.
this.emit('modechange', mode, oldMode);
};
/**
* Main button was clicked.
*/
WebVRManager.prototype.onFSClick_ = function() {
switch (this.mode) {
case Modes.NORMAL:
// TODO: Remove this hack if/when iOS gets real fullscreen mode.
// If this is an iframe on iOS, break out and open in no_fullscreen mode.
if (Util.isIOS() && Util.isIFrame()) {
if (this.fullscreenCallback) {
this.fullscreenCallback();
} else {
var url = window.location.href;
url = Util.appendQueryParameter(url, 'no_fullscreen', 'true');
url = Util.appendQueryParameter(url, 'start_mode', Modes.MAGIC_WINDOW);
top.location.href = url;
return;
}
}
this.setMode_(Modes.MAGIC_WINDOW);
this.requestFullscreen_();
break;
case Modes.MAGIC_WINDOW:
if (this.isFullscreenDisabled) {
window.history.back();
return;
}
if (this.exitFullscreenCallback) {
this.exitFullscreenCallback();
}
this.setMode_(Modes.NORMAL);
this.exitFullscreen_();
break;
}
};
/**
* The VR button was clicked.
*/
WebVRManager.prototype.onVRClick_ = function() {
// TODO: Remove this hack when iOS has fullscreen mode.
// If this is an iframe on iOS, break out and open in no_fullscreen mode.
if (this.mode == Modes.NORMAL && Util.isIOS() && Util.isIFrame()) {
if (this.vrCallback) {
this.vrCallback();
} else {
var url = window.location.href;
url = Util.appendQueryParameter(url, 'no_fullscreen', 'true');
url = Util.appendQueryParameter(url, 'start_mode', Modes.VR);
top.location.href = url;
return;
}
}
this.enterVRMode_();
};
WebVRManager.prototype.requestFullscreen_ = function() {
var canvas = document.body;
//var canvas = this.renderer.domElement;
if (canvas.requestFullscreen) {
canvas.requestFullscreen();
} else if (canvas.mozRequestFullScreen) {
canvas.mozRequestFullScreen();
} else if (canvas.webkitRequestFullscreen) {
canvas.webkitRequestFullscreen();
} else if (canvas.msRequestFullscreen) {
canvas.msRequestFullscreen();
}
};
WebVRManager.prototype.exitFullscreen_ = function() {
if (document.exitFullscreen) {
document.exitFullscreen();
} else if (document.mozCancelFullScreen) {
document.mozCancelFullScreen();
} else if (document.webkitExitFullscreen) {
document.webkitExitFullscreen();
} else if (document.msExitFullscreen) {
document.msExitFullscreen();
}
};
WebVRManager.prototype.onVRDisplayPresentChange_ = function(e) {
console.log('onVRDisplayPresentChange_', e);
if (this.hmd.isPresenting) {
this.setMode_(Modes.VR);
} else {
this.setMode_(Modes.NORMAL);
}
};
WebVRManager.prototype.onVRDisplayDeviceParamsChange_ = function(e) {
console.log('onVRDisplayDeviceParamsChange_', e);
};
WebVRManager.prototype.onFullscreenChange_ = function(e) {
// If we leave full-screen, go back to normal mode.
if (document.webkitFullscreenElement === null ||
document.mozFullScreenElement === null) {
this.setMode_(Modes.NORMAL);
}
};
module.exports = WebVRManager;
},{"./button-manager.js":1,"./emitter.js":2,"./modes.js":3,"./util.js":4}]},{},[5])(5)
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/_browser-pack@6.1.0@browser-pack/_prelude.js","src/button-manager.js","src/emitter.js","src/modes.js","src/util.js","src/webvr-manager.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","/*\r\n * Copyright 2015 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nvar Emitter = require('./emitter.js');\r\nvar Modes = require('./modes.js');\r\nvar Util = require('./util.js');\r\n\r\n/**\r\n * Everything having to do with the WebVR button.\r\n * Emits a 'click' event when it's clicked.\r\n */\r\nfunction ButtonManager(opt_root) {\r\n  var root = opt_root || document.body;\r\n  this.loadIcons_();\r\n\r\n  // Make the fullscreen button.\r\n  var fsButton = this.createButton();\r\n  fsButton.src = this.ICONS.fullscreen;\r\n  fsButton.title = 'Fullscreen mode';\r\n  var s = fsButton.style;\r\n  s.bottom = 0;\r\n  s.right = 0;\r\n  fsButton.addEventListener('click', this.createClickHandler_('fs'));\r\n  root.appendChild(fsButton);\r\n  this.fsButton = fsButton;\r\n\r\n  // Make the VR button.\r\n  var vrButton = this.createButton();\r\n  vrButton.src = this.ICONS.cardboard;\r\n  vrButton.title = 'Virtual reality mode';\r\n  var s = vrButton.style;\r\n  s.bottom = 0;\r\n  s.right = '48px';\r\n  vrButton.addEventListener('click', this.createClickHandler_('vr'));\r\n  root.appendChild(vrButton);\r\n  this.vrButton = vrButton;\r\n\r\n  this.isVisible = true;\r\n\r\n}\r\nButtonManager.prototype = new Emitter();\r\n\r\nButtonManager.prototype.createButton = function() {\r\n  var button = document.createElement('img');\r\n  button.className = 'webvr-button';\r\n  var s = button.style;\r\n  s.position = 'absolute';\r\n  s.width = '24px'\r\n  s.height = '24px';\r\n  s.backgroundSize = 'cover';\r\n  s.backgroundColor = 'transparent';\r\n  s.border = 0;\r\n  s.userSelect = 'none';\r\n  s.webkitUserSelect = 'none';\r\n  s.MozUserSelect = 'none';\r\n  s.cursor = 'pointer';\r\n  s.padding = '12px';\r\n  s.zIndex = 1;\r\n  s.display = 'none';\r\n  s.boxSizing = 'content-box';\r\n\r\n  // Prevent button from being selected and dragged.\r\n  button.draggable = false;\r\n  button.addEventListener('dragstart', function(e) {\r\n    e.preventDefault();\r\n  });\r\n\r\n  // Style it on hover.\r\n  button.addEventListener('mouseenter', function(e) {\r\n    s.filter = s.webkitFilter = 'drop-shadow(0 0 5px rgba(255,255,255,1))';\r\n  });\r\n  button.addEventListener('mouseleave', function(e) {\r\n    s.filter = s.webkitFilter = '';\r\n  });\r\n  return button;\r\n};\r\n\r\nButtonManager.prototype.setMode = function(mode, isVRCompatible) {\r\n  isVRCompatible = isVRCompatible || WebVRConfig.FORCE_ENABLE_VR;\r\n  if (!this.isVisible) {\r\n    return;\r\n  }\r\n  switch (mode) {\r\n    case Modes.NORMAL:\r\n      this.fsButton.style.display = 'block';\r\n      this.fsButton.src = this.ICONS.fullscreen;\r\n      this.vrButton.style.display = (isVRCompatible ? 'block' : 'none');\r\n      break;\r\n    case Modes.MAGIC_WINDOW:\r\n      this.fsButton.style.display = 'block';\r\n      this.fsButton.src = this.ICONS.exitFullscreen;\r\n      this.vrButton.style.display = 'none';\r\n      break;\r\n    case Modes.VR:\r\n      this.fsButton.style.display = 'none';\r\n      this.vrButton.style.display = 'none';\r\n      break;\r\n  }\r\n\r\n  // Hack for Safari Mac/iOS to force relayout (svg-specific issue)\r\n  // http://goo.gl/hjgR6r\r\n  var oldValue = this.fsButton.style.display;\r\n  this.fsButton.style.display = 'inline-block';\r\n  this.fsButton.offsetHeight;\r\n  this.fsButton.style.display = oldValue;\r\n};\r\n\r\nButtonManager.prototype.setVisibility = function(isVisible) {\r\n  this.isVisible = isVisible;\r\n  this.fsButton.style.display = isVisible ? 'block' : 'none';\r\n  this.vrButton.style.display = isVisible ? 'block' : 'none';\r\n};\r\n\r\nButtonManager.prototype.createClickHandler_ = function(eventName) {\r\n  return function(e) {\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n    this.emit(eventName);\r\n  }.bind(this);\r\n};\r\n\r\nButtonManager.prototype.loadIcons_ = function() {\r\n  // Preload some hard-coded SVG.\r\n  this.ICONS = {};\r\n  this.ICONS.cardboard = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMjAuNzQgNkgzLjIxQzIuNTUgNiAyIDYuNTcgMiA3LjI4djEwLjQ0YzAgLjcuNTUgMS4yOCAxLjIzIDEuMjhoNC43OWMuNTIgMCAuOTYtLjMzIDEuMTQtLjc5bDEuNC0zLjQ4Yy4yMy0uNTkuNzktMS4wMSAxLjQ0LTEuMDFzMS4yMS40MiAxLjQ1IDEuMDFsMS4zOSAzLjQ4Yy4xOS40Ni42My43OSAxLjExLjc5aDQuNzljLjcxIDAgMS4yNi0uNTcgMS4yNi0xLjI4VjcuMjhjMC0uNy0uNTUtMS4yOC0xLjI2LTEuMjh6TTcuNSAxNC42MmMtMS4xNyAwLTIuMTMtLjk1LTIuMTMtMi4xMiAwLTEuMTcuOTYtMi4xMyAyLjEzLTIuMTMgMS4xOCAwIDIuMTIuOTYgMi4xMiAyLjEzcy0uOTUgMi4xMi0yLjEyIDIuMTJ6bTkgMGMtMS4xNyAwLTIuMTMtLjk1LTIuMTMtMi4xMiAwLTEuMTcuOTYtMi4xMyAyLjEzLTIuMTNzMi4xMi45NiAyLjEyIDIuMTMtLjk1IDIuMTItMi4xMiAyLjEyeiIvPgogICAgPHBhdGggZmlsbD0ibm9uZSIgZD0iTTAgMGgyNHYyNEgwVjB6Ii8+Cjwvc3ZnPgo=');\r\n  this.ICONS.fullscreen = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNNyAxNEg1djVoNXYtMkg3di0zem0tMi00aDJWN2gzVjVINXY1em0xMiA3aC0zdjJoNXYtNWgtMnYzek0xNCA1djJoM3YzaDJWNWgtNXoiLz4KPC9zdmc+Cg==');\r\n  this.ICONS.exitFullscreen = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNNSAxNmgzdjNoMnYtNUg1djJ6bTMtOEg1djJoNVY1SDh2M3ptNiAxMWgydi0zaDN2LTJoLTV2NXptMi0xMVY1aC0ydjVoNVY4aC0zeiIvPgo8L3N2Zz4K');\r\n  this.ICONS.settings = Util.base64('image/svg+xml', 'PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iI0ZGRkZGRiI+CiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+CiAgICA8cGF0aCBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMy0uNjEtLjIybC0yLjQ5IDFjLS41Mi0uNC0xLjA4LS43My0xLjY5LS45OGwtLjM4LTIuNjVDMTQuNDYgMi4xOCAxNC4yNSAyIDE0IDJoLTRjLS4yNSAwLS40Ni4xOC0uNDkuNDJsLS4zOCAyLjY1Yy0uNjEuMjUtMS4xNy41OS0xLjY5Ljk4bC0yLjQ5LTFjLS4yMy0uMDktLjQ5IDAtLjYxLjIybC0yIDMuNDZjLS4xMy4yMi0uMDcuNDkuMTIuNjRsMi4xMSAxLjY1Yy0uMDQuMzItLjA3LjY1LS4wNy45OHMuMDMuNjYuMDcuOThsLTIuMTEgMS42NWMtLjE5LjE1LS4yNC40Mi0uMTIuNjRsMiAzLjQ2Yy4xMi4yMi4zOS4zLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjAzLjI0LjI0LjQyLjQ5LjQyaDRjLjI1IDAgLjQ2LS4xOC40OS0uNDJsLjM4LTIuNjVjLjYxLS4yNSAxLjE3LS41OSAxLjY5LS45OGwyLjQ5IDFjLjIzLjA5LjQ5IDAgLjYxLS4yMmwyLTMuNDZjLjEyLS4yMi4wNy0uNDktLjEyLS42NGwtMi4xMS0xLjY1ek0xMiAxNS41Yy0xLjkzIDAtMy41LTEuNTctMy41LTMuNXMxLjU3LTMuNSAzLjUtMy41IDMuNSAxLjU3IDMuNSAzLjUtMS41NyAzLjUtMy41IDMuNXoiLz4KPC9zdmc+Cg==');\r\n};\r\n\r\nmodule.exports = ButtonManager;\r\n","/*\r\n * Copyright 2015 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nfunction Emitter() {\r\n  this.callbacks = {};\r\n}\r\n\r\nEmitter.prototype.emit = function(eventName) {\r\n  var callbacks = this.callbacks[eventName];\r\n  if (!callbacks) {\r\n    //console.log('No valid callback specified.');\r\n    return;\r\n  }\r\n  var args = [].slice.call(arguments);\r\n  // Eliminate the first param (the callback).\r\n  args.shift();\r\n  for (var i = 0; i < callbacks.length; i++) {\r\n    callbacks[i].apply(this, args);\r\n  }\r\n};\r\n\r\nEmitter.prototype.on = function(eventName, callback) {\r\n  if (eventName in this.callbacks) {\r\n    this.callbacks[eventName].push(callback);\r\n  } else {\r\n    this.callbacks[eventName] = [callback];\r\n  }\r\n};\r\n\r\nmodule.exports = Emitter;\r\n","/*\r\n * Copyright 2015 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nvar Modes = {\r\n  UNKNOWN: 0,\r\n  // Not fullscreen, just tracking.\r\n  NORMAL: 1,\r\n  // Magic window immersive mode.\r\n  MAGIC_WINDOW: 2,\r\n  // Full screen split screen VR mode.\r\n  VR: 3,\r\n};\r\n\r\nmodule.exports = Modes;\r\n","/*\r\n * Copyright 2015 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nvar Util = {};\r\n\r\nUtil.base64 = function(mimeType, base64) {\r\n  return 'data:' + mimeType + ';base64,' + base64;\r\n};\r\n\r\nUtil.isMobile = function() {\r\n  var check = false;\r\n  (function(a){if(/(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\\-(n|u)|c55\\/|capi|ccwa|cdm\\-|cell|chtm|cldc|cmd\\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\\-s|devi|dica|dmob|do(c|p)o|ds(12|\\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\\-|_)|g1 u|g560|gene|gf\\-5|g\\-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd\\-(m|p|t)|hei\\-|hi(pt|ta)|hp( i|ip)|hs\\-c|ht(c(\\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\\-(20|go|ma)|i230|iac( |\\-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc\\-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|\\-[a-w])|libw|lynx|m1\\-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m\\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\\-2|po(ck|rt|se)|prox|psio|pt\\-g|qa\\-a|qc(07|12|21|32|60|\\-[2-7]|i\\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\\-|oo|p\\-)|sdk\\/|se(c(\\-|0|1)|47|mc|nd|ri)|sgh\\-|shar|sie(\\-|m)|sk\\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\\-|v\\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\\-|tdg\\-|tel(i|m)|tim\\-|t\\-mo|to(pl|sh)|ts(70|m\\-|m3|m5)|tx\\-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\\-|your|zeto|zte\\-/i.test(a.substr(0,4)))check = true})(navigator.userAgent||navigator.vendor||window.opera);\r\n  return check;\r\n};\r\n\r\nUtil.isFirefox = function() {\r\n  return /firefox/i.test(navigator.userAgent);\r\n};\r\n\r\nUtil.isIOS = function() {\r\n  return /(iPad|iPhone|iPod)/g.test(navigator.userAgent);\r\n};\r\n\r\nUtil.isIFrame = function() {\r\n  try {\r\n    return window.self !== window.top;\r\n  } catch (e) {\r\n    return true;\r\n  }\r\n};\r\n\r\nUtil.appendQueryParameter = function(url, key, value) {\r\n  // Determine delimiter based on if the URL already GET parameters in it.\r\n  var delimiter = (url.indexOf('?') < 0 ? '?' : '&');\r\n  url += delimiter + key + '=' + value;\r\n  return url;\r\n};\r\n\r\n// From http://goo.gl/4WX3tg\r\nUtil.getQueryParameter = function(name) {\r\n  var name = name.replace(/[\\[]/, \"\\\\[\").replace(/[\\]]/, \"\\\\]\");\r\n  var regex = new RegExp(\"[\\\\?&]\" + name + \"=([^&#]*)\"),\r\n      results = regex.exec(location.search);\r\n  return results === null ? \"\" : decodeURIComponent(results[1].replace(/\\+/g, \" \"));\r\n};\r\n\r\nUtil.isLandscapeMode = function() {\r\n  return (window.orientation == 90 || window.orientation == -90);\r\n};\r\n\r\nUtil.getScreenWidth = function() {\r\n  return Math.max(window.screen.width, window.screen.height) *\r\n      window.devicePixelRatio;\r\n};\r\n\r\nUtil.getScreenHeight = function() {\r\n  return Math.min(window.screen.width, window.screen.height) *\r\n      window.devicePixelRatio;\r\n};\r\n\r\nmodule.exports = Util;\r\n","/*\r\n * Copyright 2015 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nvar ButtonManager = require('./button-manager.js');\r\nvar Emitter = require('./emitter.js');\r\nvar Modes = require('./modes.js');\r\nvar Util = require('./util.js');\r\n\r\n/**\r\n * Helper for getting in and out of VR mode.\r\n */\r\nfunction WebVRManager(renderer, effect, params) {\r\n  this.params = params || {};\r\n\r\n  this.mode = Modes.UNKNOWN;\r\n\r\n  // Set option to hide the button.\r\n  this.hideButton = this.params.hideButton || false;\r\n  // Whether or not the FOV should be distorted or un-distorted. By default, it\r\n  // should be distorted, but in the case of vertex shader based distortion,\r\n  // ensure that we use undistorted parameters.\r\n  this.predistorted = !!this.params.predistorted;\r\n\r\n  // Save the THREE.js renderer and effect for later.\r\n  this.renderer = renderer;\r\n  this.effect = effect;\r\n  var polyfillWrapper = document.querySelector('.webvr-polyfill-fullscreen-wrapper');\r\n  this.button = new ButtonManager(polyfillWrapper);\r\n\r\n  this.isFullscreenDisabled = !!Util.getQueryParameter('no_fullscreen');\r\n  this.startMode = Modes.NORMAL;\r\n  var startModeParam = parseInt(Util.getQueryParameter('start_mode'));\r\n  if (!isNaN(startModeParam)) {\r\n    this.startMode = startModeParam;\r\n  }\r\n\r\n  if (this.hideButton) {\r\n    this.button.setVisibility(false);\r\n  }\r\n\r\n  // Check if the browser is compatible with WebVR.\r\n  this.getDeviceByType_(VRDisplay).then(function(hmd) {\r\n    this.hmd = hmd;\r\n\r\n    // Only enable VR mode if there's a VR device attached or we are running the\r\n    // polyfill on mobile.\r\n    if (!this.isVRCompatibleOverride) {\r\n      this.isVRCompatible =  !hmd.isPolyfilled || Util.isMobile();\r\n    }\r\n\r\n    switch (this.startMode) {\r\n      case Modes.MAGIC_WINDOW:\r\n        this.setMode_(Modes.MAGIC_WINDOW);\r\n        break;\r\n      case Modes.VR:\r\n        this.enterVRMode_();\r\n        this.setMode_(Modes.VR);\r\n        break;\r\n      default:\r\n        this.setMode_(Modes.NORMAL);\r\n    }\r\n\r\n    this.emit('initialized');\r\n  }.bind(this));\r\n\r\n  // Hook up button listeners.\r\n  this.button.on('fs', this.onFSClick_.bind(this));\r\n  this.button.on('vr', this.onVRClick_.bind(this));\r\n\r\n  // Bind to fullscreen events.\r\n  document.addEventListener('webkitfullscreenchange',\r\n      this.onFullscreenChange_.bind(this));\r\n  document.addEventListener('mozfullscreenchange',\r\n      this.onFullscreenChange_.bind(this));\r\n  document.addEventListener('msfullscreenchange',\r\n      this.onFullscreenChange_.bind(this));\r\n\r\n  // Bind to VR* specific events.\r\n  window.addEventListener('vrdisplaypresentchange',\r\n      this.onVRDisplayPresentChange_.bind(this));\r\n  window.addEventListener('vrdisplaydeviceparamschange',\r\n      this.onVRDisplayDeviceParamsChange_.bind(this));\r\n}\r\n\r\nWebVRManager.prototype = new Emitter();\r\n\r\n// Expose these values externally.\r\nWebVRManager.Modes = Modes;\r\n\r\nWebVRManager.prototype.render = function(scene, camera, timestamp) {\r\n  // Scene may be an array of two scenes, one for each eye.\r\n  if (scene instanceof Array) {\r\n    this.effect.render(scene[0], camera);\r\n  } else {\r\n    this.effect.render(scene, camera);\r\n  }\r\n};\r\n\r\nWebVRManager.prototype.setVRCompatibleOverride = function(isVRCompatible) {\r\n  this.isVRCompatible = isVRCompatible;\r\n  this.isVRCompatibleOverride = true;\r\n\r\n  // Don't actually change modes, just update the buttons.\r\n  this.button.setMode(this.mode, this.isVRCompatible);\r\n};\r\n\r\nWebVRManager.prototype.setFullscreenCallback = function(callback) {\r\n  this.fullscreenCallback = callback;\r\n};\r\n\r\nWebVRManager.prototype.setVRCallback = function(callback) {\r\n  this.vrCallback = callback;\r\n};\r\n\r\nWebVRManager.prototype.setExitFullscreenCallback = function(callback) {\r\n  this.exitFullscreenCallback = callback;\r\n}\r\n\r\n/**\r\n * Promise returns true if there is at least one HMD device available.\r\n */\r\nWebVRManager.prototype.getDeviceByType_ = function(type) {\r\n  return new Promise(function(resolve, reject) {\r\n    navigator.getVRDisplays().then(function(displays) {\r\n      // Promise succeeds, but check if there are any displays actually.\r\n      for (var i = 0; i < displays.length; i++) {\r\n        if (displays[i] instanceof type) {\r\n          resolve(displays[i]);\r\n          break;\r\n        }\r\n      }\r\n      resolve(null);\r\n    }, function() {\r\n      // No displays are found.\r\n      resolve(null);\r\n    });\r\n  });\r\n};\r\n\r\n/**\r\n * Helper for entering VR mode.\r\n */\r\nWebVRManager.prototype.enterVRMode_ = function() {\r\n  this.hmd.requestPresent([{\r\n    source: this.renderer.domElement,\r\n    predistorted: this.predistorted\r\n  }]);\r\n};\r\n\r\nWebVRManager.prototype.setMode_ = function(mode) {\r\n  var oldMode = this.mode;\r\n  if (mode == this.mode) {\r\n    console.warn('Not changing modes, already in %s', mode);\r\n    return;\r\n  }\r\n  // console.log('Mode change: %s => %s', this.mode, mode);\r\n  this.mode = mode;\r\n  this.button.setMode(mode, this.isVRCompatible);\r\n\r\n  // Emit an event indicating the mode changed.\r\n  this.emit('modechange', mode, oldMode);\r\n};\r\n\r\n/**\r\n * Main button was clicked.\r\n */\r\nWebVRManager.prototype.onFSClick_ = function() {\r\n  switch (this.mode) {\r\n    case Modes.NORMAL:\r\n      // TODO: Remove this hack if/when iOS gets real fullscreen mode.\r\n      // If this is an iframe on iOS, break out and open in no_fullscreen mode.\r\n      if (Util.isIOS() && Util.isIFrame()) {\r\n        if (this.fullscreenCallback) {\r\n          this.fullscreenCallback();\r\n        } else {\r\n          var url = window.location.href;\r\n          url = Util.appendQueryParameter(url, 'no_fullscreen', 'true');\r\n          url = Util.appendQueryParameter(url, 'start_mode', Modes.MAGIC_WINDOW);\r\n          top.location.href = url;\r\n          return;\r\n        }\r\n      }\r\n      this.setMode_(Modes.MAGIC_WINDOW);\r\n      this.requestFullscreen_();\r\n      break;\r\n    case Modes.MAGIC_WINDOW:\r\n      if (this.isFullscreenDisabled) {\r\n        window.history.back();\r\n        return;\r\n      }\r\n      if (this.exitFullscreenCallback) {\r\n        this.exitFullscreenCallback();\r\n      }\r\n      this.setMode_(Modes.NORMAL);\r\n      this.exitFullscreen_();\r\n      break;\r\n  }\r\n};\r\n\r\n/**\r\n * The VR button was clicked.\r\n */\r\nWebVRManager.prototype.onVRClick_ = function() {\r\n  // TODO: Remove this hack when iOS has fullscreen mode.\r\n  // If this is an iframe on iOS, break out and open in no_fullscreen mode.\r\n  if (this.mode == Modes.NORMAL && Util.isIOS() && Util.isIFrame()) {\r\n    if (this.vrCallback) {\r\n      this.vrCallback();\r\n    } else {\r\n      var url = window.location.href;\r\n      url = Util.appendQueryParameter(url, 'no_fullscreen', 'true');\r\n      url = Util.appendQueryParameter(url, 'start_mode', Modes.VR);\r\n      top.location.href = url;\r\n      return;\r\n    }\r\n  }\r\n  this.enterVRMode_();\r\n};\r\n\r\nWebVRManager.prototype.requestFullscreen_ = function() {\r\n  var canvas = document.body;\r\n  //var canvas = this.renderer.domElement;\r\n  if (canvas.requestFullscreen) {\r\n    canvas.requestFullscreen();\r\n  } else if (canvas.mozRequestFullScreen) {\r\n    canvas.mozRequestFullScreen();\r\n  } else if (canvas.webkitRequestFullscreen) {\r\n    canvas.webkitRequestFullscreen();\r\n  } else if (canvas.msRequestFullscreen) {\r\n    canvas.msRequestFullscreen();\r\n  }\r\n};\r\n\r\nWebVRManager.prototype.exitFullscreen_ = function() {\r\n  if (document.exitFullscreen) {\r\n    document.exitFullscreen();\r\n  } else if (document.mozCancelFullScreen) {\r\n    document.mozCancelFullScreen();\r\n  } else if (document.webkitExitFullscreen) {\r\n    document.webkitExitFullscreen();\r\n  } else if (document.msExitFullscreen) {\r\n    document.msExitFullscreen();\r\n  }\r\n};\r\n\r\nWebVRManager.prototype.onVRDisplayPresentChange_ = function(e) {\r\n  console.log('onVRDisplayPresentChange_', e);\r\n  if (this.hmd.isPresenting) {\r\n    this.setMode_(Modes.VR);\r\n  } else {\r\n    this.setMode_(Modes.NORMAL);\r\n  }\r\n};\r\n\r\nWebVRManager.prototype.onVRDisplayDeviceParamsChange_ = function(e) {\r\n  console.log('onVRDisplayDeviceParamsChange_', e);\r\n};\r\n\r\nWebVRManager.prototype.onFullscreenChange_ = function(e) {\r\n  // If we leave full-screen, go back to normal mode.\r\n  if (document.webkitFullscreenElement === null ||\r\n      document.mozFullScreenElement === null) {\r\n    this.setMode_(Modes.NORMAL);\r\n  }\r\n};\r\n\r\nmodule.exports = WebVRManager;\r\n"]}
JavaScript
1
https://gitee.com/jinzhexian/vr-stream-web-player.git
git@gitee.com:jinzhexian/vr-stream-web-player.git
jinzhexian
vr-stream-web-player
vr-stream-web-player
master

搜索帮助