Skip to content

Instantly share code, notes, and snippets.

@CodeMyUI
Created August 14, 2019 03:46
Show Gist options
  • Save CodeMyUI/021c5294b452ce4fe5fc36ffb0061f10 to your computer and use it in GitHub Desktop.
Save CodeMyUI/021c5294b452ce4fe5fc36ffb0061f10 to your computer and use it in GitHub Desktop.
360° Video
<div id="container"></div>
<a id="play_btn" href='javascript:;'>Click to Load</a>
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, {
/******/ configurable: false,
/******/ enumerable: true,
/******/ get: getter
/******/ });
/******/ }
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = 0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__css_css_css__ = __webpack_require__(1);
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__css_css_css___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__css_css_css__);
/**
* Created by sanchez
*/
// import CSS
// import animate_css from 'animate.css/animate.min.css';
// import scss from '../css/sass.scss';
// require('aframe');
// require('t')
// window.Detector = require('./entities/Detector');
// require('./entities/CanvasRenderer');
// require('./entities/Projector');
// require('jquery.valiant360');
// import Js Plugins/Entities
//ES6 Module
// import Bar1 from './entities/Bar1';
// import Howler from 'howler';
// //CommonJS
// var Bar2=require('./entities/Bar2');
if (/Mobile/i.test(navigator.userAgent)) {
window.isMobile = true;
} else {
window.isMobile = false;
}
window.h5 = {
initThree360: function() {
var camera, scene, renderer;
var texture_placeholder,
isUserInteracting = false,
onMouseDownMouseX = 0,
onMouseDownMouseY = 0,
lon = 0,
onMouseDownLon = 0,
lat = 0,
onMouseDownLat = 0,
phi = 0,
theta = 0,
distance = 500,
onPointerDownPointerX = 0,
onPointerDownPointerY = 0,
onPointerDownLon = 0,
onPointerDownLat = 0;
init();
// animate();
function init() {
var container, mesh;
window.loaded = false;
container = document.getElementById('container');
camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 1, 1100);
camera.target = new THREE.Vector3(0, 0, 0);
scene = new THREE.Scene();
var geometry = new THREE.SphereBufferGeometry(500, 60, 40);
// invert the geometry on the x-axis so that all of the faces point inward
geometry.scale(-1, 1, 1);
var play_btn = document.getElementById('play_btn');
var video = document.createElement('video');
video.width = 640;
video.height = 360;
video.loop = true;
video.muted = true;
video.src = 'http://flimshaw.github.io/Valiant360/videos/overpass-2k.mp4';
video.setAttribute('webkit-playsinline', 'webkit-playsinline');
video.setAttribute('playsinline', 'playsinline');
video.setAttribute('x5-video-player-fullscreen', 'false');
video.setAttribute('x5-video-player-type', 'h5');
video.setAttribute('x-webkit-airplay', 'true');
video.crossOrigin = "Anonymous";
// play_btn.innerHTML = 'Play';
var texture = new THREE.VideoTexture(video);
texture.minFilter = THREE.LinearFilter;
texture.format = THREE.RGBFormat;
var material = new THREE.MeshBasicMaterial({ map: texture });
mesh = new THREE.Mesh(geometry, material);
scene.add(mesh);
renderer = new THREE.WebGLRenderer();
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
container.appendChild(renderer.domElement);
animate();
play_btn.addEventListener('click', function() {
play_btn.innerHTML = 'Play';
if (!window.loaded) {
// video.pause();
window.loaded = true;
} else {
video.play();
play_btn.style.display = 'none';
}
}, true);
var eventstart, eventmove, eventstart;
document.addEventListener('touchstart', function(e) {}, false);
document.addEventListener('touchmove', function(e) {
e.preventDefault();
}, false);
container.addEventListener('touchstart', onDocumenTouchDown, false);
container.addEventListener('touchmove', onDocumentTouchMove, false);
container.addEventListener('touchend', onDocumentTouchUp, false);
container.addEventListener('mousedown', onDocumentMouseDown, false);
container.addEventListener('mousemove', onDocumentMouseMove, false);
container.addEventListener('mouseup', onDocumentMouseUp, false);
window.addEventListener('resize', onWindowResize, false);
}
function onWindowResize() {
if (/Mobile/i.test(navigator.userAgent)) {
window.isMobile = true;
} else {
window.isMobile = false;
}
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize(window.innerWidth, window.innerHeight);
}
function onDocumentMouseDown(event) {
event.preventDefault();
isUserInteracting = true;
onPointerDownPointerX = event.clientX;
onPointerDownPointerY = event.clientY;
onPointerDownLon = lon;
onPointerDownLat = lat;
}
function onDocumentMouseMove(event) {
if (isUserInteracting === true) {
lon = (onPointerDownPointerX - event.clientX) * 0.5 + onPointerDownLon;
lat = (event.clientY - onPointerDownPointerY) * 0.5 + onPointerDownLat;
}
}
function onDocumentMouseUp(event) {
isUserInteracting = false;
}
function onDocumenTouchDown(event) {
event.preventDefault();
isUserInteracting = true;
onPointerDownPointerX = event.touches[0].clientX;
onPointerDownPointerY = event.touches[0].clientY;
onPointerDownLon = lon;
onPointerDownLat = lat;
}
function onDocumentTouchMove(event) {
if (isUserInteracting === true) {
lon = (onPointerDownPointerX - event.touches[0].clientX) * 0.5 + onPointerDownLon;
lat = (event.touches[0].clientY - onPointerDownPointerY) * 0.5 + onPointerDownLat;
}
}
function onDocumentTouchUp(event) {
isUserInteracting = false;
}
function animate() {
requestAnimationFrame(animate);
update();
}
function update() {
lat = Math.max(-85, Math.min(85, lat));
phi = THREE.Math.degToRad(90 - lat);
theta = THREE.Math.degToRad(lon);
camera.position.x = distance * Math.sin(phi) * Math.cos(theta);
camera.position.y = distance * Math.cos(phi);
camera.position.z = distance * Math.sin(phi) * Math.sin(theta);
camera.lookAt(camera.target);
/*
// distortion
camera.position.copy( camera.target ).negate();
*/
renderer.render(scene, camera);
}
},
initValiant360: function() {
var play_btn = document.getElementById('play_btn');
$('.valiantContainer').Valiant360();
play_btn.addEventListener('click', function() {
// play
$('.valiantContainer').Valiant360('play');
$('.valiantContainer').Valiant360('pause');
}, false);
$('.valiantContainer').Valiant360('loadVideo', './assets/media/city.mp4');
$('.valiantContainer').Valiant360('play');
// $('.valiantContainer').Valiant360('pause');
},
rootResize2: function() {
//orientation landscape width=1334px
var wFsize;
var wWidth = (screen.width > 0) ? (window.innerWidth >= screen.width || window.innerWidth == 0) ? screen.width :
window.innerWidth : window.innerWidth;
var wHeight = (screen.height > 0) ? (window.innerHeight >= screen.height || window.innerHeight == 0) ?
screen.height : window.innerHeight : window.innerHeight;
if (wWidth > wHeight) {
wHeight = wWidth;
}
wFsize = wHeight / 13.34;
document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';
},
rootResize1: function() {
//orientation landscape width=1334px
var that = this;
var Dpr = 1,
uAgent = window.navigator.userAgent;
var isIOS = uAgent.match(/iphone/i);
var isYIXIN = uAgent.match(/yixin/i);
var is2345 = uAgent.match(/Mb2345/i);
var ishaosou = uAgent.match(/mso_app/i);
var isSogou = uAgent.match(/sogoumobilebrowser/ig);
var isLiebao = uAgent.match(/liebaofast/i);
var isGnbr = uAgent.match(/GNBR/i);
var isWeixin = uAgent.match(/MicroMessenger/i);
var wFsize;
var wWidth = (screen.width > 0) ? (window.innerWidth >= screen.width || window.innerWidth == 0) ? screen.width :
window.innerWidth : window.innerWidth;
var wHeight = (screen.height > 0) ? (window.innerHeight >= screen.height || window.innerHeight == 0) ?
screen.height : window.innerHeight : window.innerHeight;
if (isIOS) {
wWidth = screen.width;
wHeight = screen.height;
}
if (wWidth > wHeight) {
wHeight = wWidth;
}
wFsize = wHeight / 13.34;
if (isYIXIN || is2345 || ishaosou || isSogou || isLiebao || isGnbr || isWeixin) { //YIXIN 和 2345 这里有个刚调用系统浏览器时候的bug,需要一点延迟来获取
setTimeout(function() {
wHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
wWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;
if (wWidth > wHeight) {
wHeight = wWidth;
}
wFsize = wHeight / 13.34;
// wFsize = wFsize > 32 ? wFsize : 32;
document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';
}, 500);
} else {
document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';
}
return that;
},
eventInit: function() {
var that = this;
document.addEventListener('touchstart', function(e) {}, false);
document.addEventListener('touchmove', function(e) {
e.preventDefault();
}, false);
return that;
},
cssInit: function() {
var that = this;
/*
that.rootResize1();
window.addEventListener("onorientationchange" in window ? "orientationchange" : "resize", function() {
if (window.orientation == 90 || window.orientation == -90) {
//横屏
//_.renderShuping();
that.rootResize();
} else {
//竖屏
//_.closeShuping();
}
}, false);
*/
var noChangeCountToEnd = 100,
noEndTimeout = 1000;
that.rootResize2();
window.addEventListener("onorientationchange" in window ? "orientationchange" : "resize", function() {
var interval,
timeout,
end,
lastInnerWidth,
lastInnerHeight,
noChangeCount;
end = function() {
// "orientationchangeend"
clearInterval(interval);
clearTimeout(timeout);
interval = null;
timeout = null;
that.rootResize1();
};
interval = setInterval(function() {
if (window.innerWidth === lastInnerWidth && window.innerHeight === lastInnerHeight) {
noChangeCount++;
if (noChangeCount === noChangeCountToEnd) {
// The interval resolved the issue first.
end();
}
} else {
lastInnerWidth = window.innerWidth;
lastInnerHeight = window.innerHeight;
noChangeCount = 0;
}
});
timeout = setTimeout(function() {
// The timeout happened first.
end();
}, noEndTimeout);
});
return that;
}
};
window.h5.initThree360();
// window.h5.initValiant360();
// window.h5.cssInit().eventInit();
function showStats() {
var stats = new Stats();
stats.showPanel(0); // 0: fps, 1: ms, 2: mb, 3+: custom
var fs = document.createElement('div');
fs.style.position = 'absolute';
fs.style.left = 0;
fs.style.top = 0;
fs.style.zIndex = 999;
fs.appendChild(stats.domElement);
document.body.appendChild(fs);
function animate() {
stats.begin();
// monitored code goes here
stats.end();
requestAnimationFrame(animate);
}
requestAnimationFrame(animate);
}
showStats();
/***/ }),
/* 1 */
/***/ (function(module, exports) {
// removed by extract-text-webpack-plugin
/***/ })
/******/ ]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap 975efdff0d82976a32a9","webpack:///./src/assets/js/main.js","webpack:///./src/assets/css/css.css"],"names":[],"mappings":";AAAA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;AAEA;AACA;;;;;;;;;AC7DA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA,wDAAwD,eAAe;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,aAAa;AACb;;AAEA,kEAAkE;AAClE;AACA;AACA,aAAa;;AAEb;AACA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yFAAyF;AACzF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;;AAEA;;AAEA,KAAK;AACL;AACA;AACA,8DAA8D;AAC9D;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,Y;;;;;;ACnWA,yC","file":"assets/js/main.min.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 975efdff0d82976a32a9","/**\n * Created by sanchez \n */\n'use strict';\n// import CSS\n// import animate_css from 'animate.css/animate.min.css';\nimport css from '../css/css.css';\n// import scss from '../css/sass.scss';\n\n\n// require('aframe');\n// require('t')\n// window.Detector = require('./entities/Detector');\n// require('./entities/CanvasRenderer');\n// require('./entities/Projector');\n// require('jquery.valiant360');\n// import Js Plugins/Entities\n\n//ES6 Module\n// import Bar1 from './entities/Bar1';\n// import Howler from 'howler';\n// //CommonJS\n// var Bar2=require('./entities/Bar2');\n\nif (/Mobile/i.test(navigator.userAgent)) {\n    window.isMobile = true;\n} else {\n    window.isMobile = false;\n}\n\n\nwindow.h5 = {\n    initThree360: function() {\n        var camera, scene, renderer;\n        var texture_placeholder,\n            isUserInteracting = false,\n            onMouseDownMouseX = 0,\n            onMouseDownMouseY = 0,\n            lon = 0,\n            onMouseDownLon = 0,\n            lat = 0,\n            onMouseDownLat = 0,\n            phi = 0,\n            theta = 0,\n            distance = 500,\n            onPointerDownPointerX = 0,\n            onPointerDownPointerY = 0,\n            onPointerDownLon = 0,\n            onPointerDownLat = 0;\n        init();\n        // animate();\n\n        function init() {\n            var container, mesh;\n            window.loaded = false;\n            container = document.getElementById('container');\n            camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 1, 1100);\n            camera.target = new THREE.Vector3(0, 0, 0);\n            scene = new THREE.Scene();\n            var geometry = new THREE.SphereBufferGeometry(500, 60, 40);\n            // invert the geometry on the x-axis so that all of the faces point inward\n            geometry.scale(-1, 1, 1);\n            var play_btn = document.getElementById('play_btn');\n            var video = document.createElement('video');\n            video.width = 640;\n            video.height = 360;\n            video.loop = true;\n            video.muted = true;\n\n            video.src = 'http://flimshaw.github.io/Valiant360/videos/overpass-2k.mp4';\n            video.setAttribute('webkit-playsinline', 'webkit-playsinline');\n            video.setAttribute('playsinline', 'playsinline');\n            video.setAttribute('x5-video-player-fullscreen', 'false');\n            video.setAttribute('x5-video-player-type', 'h5');\n            video.setAttribute('x-webkit-airplay', 'true');\n            video.crossOrigin = \"Anonymous\";\n\n\n            // play_btn.innerHTML = 'Play';\n            var texture = new THREE.VideoTexture(video);\n            texture.minFilter = THREE.LinearFilter;\n            texture.format = THREE.RGBFormat;\n            var material = new THREE.MeshBasicMaterial({ map: texture });\n            mesh = new THREE.Mesh(geometry, material);\n            scene.add(mesh);\n            renderer = new THREE.WebGLRenderer();\n            renderer.setPixelRatio(window.devicePixelRatio);\n            renderer.setSize(window.innerWidth, window.innerHeight);\n            container.appendChild(renderer.domElement);\n            animate();\n\n\n            play_btn.addEventListener('click', function() {\n                play_btn.innerHTML = 'Play';\n                if (!window.loaded) {\n                    // video.pause();\n                    window.loaded = true;\n                } else {\n                    video.play();\n                    play_btn.style.display = 'none';\n                }\n            }, true);\n            var eventstart, eventmove, eventstart;\n\n            document.addEventListener('touchstart', function(e) {}, false);\n            document.addEventListener('touchmove', function(e) {\n                e.preventDefault();\n            }, false);\n\n            container.addEventListener('touchstart', onDocumenTouchDown, false);\n            container.addEventListener('touchmove', onDocumentTouchMove, false);\n            container.addEventListener('touchend', onDocumentTouchUp, false);\n\n            container.addEventListener('mousedown', onDocumentMouseDown, false);\n            container.addEventListener('mousemove', onDocumentMouseMove, false);\n            container.addEventListener('mouseup', onDocumentMouseUp, false);\n\n\n            window.addEventListener('resize', onWindowResize, false);\n        }\n\n        function onWindowResize() {\n            if (/Mobile/i.test(navigator.userAgent)) {\n                window.isMobile = true;\n            } else {\n                window.isMobile = false;\n            }\n            camera.aspect = window.innerWidth / window.innerHeight;\n            camera.updateProjectionMatrix();\n            renderer.setSize(window.innerWidth, window.innerHeight);\n        }\n\n\n        function onDocumentMouseDown(event) {\n            event.preventDefault();\n            isUserInteracting = true;\n            onPointerDownPointerX = event.clientX;\n            onPointerDownPointerY = event.clientY;\n            onPointerDownLon = lon;\n            onPointerDownLat = lat;\n        }\n\n        function onDocumentMouseMove(event) {\n\n            if (isUserInteracting === true) {\n                lon = (onPointerDownPointerX - event.clientX) * 0.5 + onPointerDownLon;\n                lat = (event.clientY - onPointerDownPointerY) * 0.5 + onPointerDownLat;\n\n            }\n        }\n\n        function onDocumentMouseUp(event) {\n            isUserInteracting = false;\n        }\n\n        function onDocumenTouchDown(event) {\n            event.preventDefault();\n            isUserInteracting = true;\n            onPointerDownPointerX = event.touches[0].clientX;\n            onPointerDownPointerY = event.touches[0].clientY;\n            onPointerDownLon = lon;\n            onPointerDownLat = lat;\n        }\n\n        function onDocumentTouchMove(event) {\n\n            if (isUserInteracting === true) {\n                lon = (onPointerDownPointerX - event.touches[0].clientX) * 0.5 + onPointerDownLon;\n                lat = (event.touches[0].clientY - onPointerDownPointerY) * 0.5 + onPointerDownLat;\n\n            }\n        }\n\n        function onDocumentTouchUp(event) {\n            isUserInteracting = false;\n        }\n\n        function animate() {\n            requestAnimationFrame(animate);\n            update();\n        }\n\n        function update() {\n            lat = Math.max(-85, Math.min(85, lat));\n            phi = THREE.Math.degToRad(90 - lat);\n            theta = THREE.Math.degToRad(lon);\n            camera.position.x = distance * Math.sin(phi) * Math.cos(theta);\n            camera.position.y = distance * Math.cos(phi);\n            camera.position.z = distance * Math.sin(phi) * Math.sin(theta);\n            camera.lookAt(camera.target);\n            /*\n            // distortion\n            camera.position.copy( camera.target ).negate();\n            */\n            renderer.render(scene, camera);\n        }\n\n    },\n    initValiant360: function() {\n        var play_btn = document.getElementById('play_btn');\n        $('.valiantContainer').Valiant360();\n        play_btn.addEventListener('click', function() {\n            // play\n            $('.valiantContainer').Valiant360('play');\n            $('.valiantContainer').Valiant360('pause');\n        }, false);\n        $('.valiantContainer').Valiant360('loadVideo', './assets/media/city.mp4');\n        $('.valiantContainer').Valiant360('play');\n        // $('.valiantContainer').Valiant360('pause');\n\n    },\n    rootResize2: function() {\n        //orientation landscape width=1334px\n        var wFsize;\n        var wWidth = (screen.width > 0) ? (window.innerWidth >= screen.width || window.innerWidth == 0) ? screen.width :\n            window.innerWidth : window.innerWidth;\n        var wHeight = (screen.height > 0) ? (window.innerHeight >= screen.height || window.innerHeight == 0) ?\n            screen.height : window.innerHeight : window.innerHeight;\n        if (wWidth > wHeight) {\n            wHeight = wWidth;\n        }\n        wFsize = wHeight / 13.34;\n        document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';\n    },\n    rootResize1: function() {\n        //orientation landscape width=1334px\n        var that = this;\n        var Dpr = 1,\n            uAgent = window.navigator.userAgent;\n        var isIOS = uAgent.match(/iphone/i);\n        var isYIXIN = uAgent.match(/yixin/i);\n        var is2345 = uAgent.match(/Mb2345/i);\n        var ishaosou = uAgent.match(/mso_app/i);\n        var isSogou = uAgent.match(/sogoumobilebrowser/ig);\n        var isLiebao = uAgent.match(/liebaofast/i);\n        var isGnbr = uAgent.match(/GNBR/i);\n        var isWeixin = uAgent.match(/MicroMessenger/i);\n        var wFsize;\n        var wWidth = (screen.width > 0) ? (window.innerWidth >= screen.width || window.innerWidth == 0) ? screen.width :\n            window.innerWidth : window.innerWidth;\n        var wHeight = (screen.height > 0) ? (window.innerHeight >= screen.height || window.innerHeight == 0) ?\n            screen.height : window.innerHeight : window.innerHeight;\n        if (isIOS) {\n            wWidth = screen.width;\n            wHeight = screen.height;\n        }\n        if (wWidth > wHeight) {\n            wHeight = wWidth;\n        }\n        wFsize = wHeight / 13.34;\n        if (isYIXIN || is2345 || ishaosou || isSogou || isLiebao || isGnbr || isWeixin) { //YIXIN 和 2345 这里有个刚调用系统浏览器时候的bug，需要一点延迟来获取\n            setTimeout(function() {\n                wHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;\n                wWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;\n                if (wWidth > wHeight) {\n                    wHeight = wWidth;\n                }\n                wFsize = wHeight / 13.34;\n                // wFsize = wFsize > 32 ? wFsize : 32;\n                document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';\n            }, 500);\n        } else {\n            document.getElementsByTagName('html')[0].style.fontSize = wFsize + 'px';\n        }\n\n        return that;\n\n    },\n    eventInit: function() {\n        var that = this;\n        document.addEventListener('touchstart', function(e) {}, false);\n        document.addEventListener('touchmove', function(e) {\n            e.preventDefault();\n        }, false);\n        return that;\n    },\n    cssInit: function() {\n        var that = this;\n        /*\n        that.rootResize1();\n        window.addEventListener(\"onorientationchange\" in window ? \"orientationchange\" : \"resize\", function() {\n            if (window.orientation == 90 || window.orientation == -90) {\n                //横屏\n                //_.renderShuping();\n                that.rootResize();\n            } else {\n                //竖屏\n                //_.closeShuping();\n            }\n        }, false);\n        */\n        var noChangeCountToEnd = 100,\n            noEndTimeout = 1000;\n        that.rootResize2();\n        window.addEventListener(\"onorientationchange\" in window ? \"orientationchange\" : \"resize\", function() {\n            var interval,\n                timeout,\n                end,\n                lastInnerWidth,\n                lastInnerHeight,\n                noChangeCount;\n            end = function() {\n                // \"orientationchangeend\"\n                clearInterval(interval);\n                clearTimeout(timeout);\n                interval = null;\n                timeout = null;\n                that.rootResize1();\n            };\n            interval = setInterval(function() {\n                if (window.innerWidth === lastInnerWidth && window.innerHeight === lastInnerHeight) {\n                    noChangeCount++;\n                    if (noChangeCount === noChangeCountToEnd) {\n                        // The interval resolved the issue first.\n                        end();\n                    }\n                } else {\n                    lastInnerWidth = window.innerWidth;\n                    lastInnerHeight = window.innerHeight;\n                    noChangeCount = 0;\n                }\n            });\n            timeout = setTimeout(function() {\n                // The timeout happened first.\n                end();\n            }, noEndTimeout);\n        });\n\n        return that;\n    }\n};\nwindow.h5.initThree360();\n// window.h5.initValiant360();\n// window.h5.cssInit().eventInit();\n\n\nfunction showStats() {\n    var stats = new Stats();\n    stats.showPanel(0); // 0: fps, 1: ms, 2: mb, 3+: custom\n    var fs = document.createElement('div');\n    fs.style.position = 'absolute';\n    fs.style.left = 0;\n    fs.style.top = 0;\n    fs.style.zIndex = 999;\n    fs.appendChild(stats.domElement);\n    document.body.appendChild(fs);\n\n    function animate() {\n        stats.begin();\n        // monitored code goes here\n        stats.end();\n        requestAnimationFrame(animate);\n    }\n    requestAnimationFrame(animate);\n}\nshowStats();\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/assets/js/main.js\n// module id = 0\n// module chunks = 0","// removed by extract-text-webpack-plugin\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/assets/css/css.css\n// module id = 1\n// module chunks = 0"],"sourceRoot":""}
<script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/87/three.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/stats.js/r16/Stats.min.js"></script>
* {
margin: 0 auto;
padding: 0;
overflow: hidden;
}
body {
width: 100%;
height: 100%;
overflow: hidden;
background-color: #000;
}
#play_btn {
position: absolute;
width: 8rem;
height: 3rem;
color: #000;
background-color: #fff;
left: 0;
right: 0;
top: 0;
bottom: 0;
margin: auto;
text-align: center;
line-height: 3rem;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment