// 图片加载进度 let myJinDu = 0 /* eslint-disable no-empty */ /* eslint-disable no-unused-vars */ /* eslint-disable no-console */ /* eslint-disable no-undef */ var isPhone = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test( navigator.userAgent ); //设置字体大小 calculateFontSize(); //计算字体大小,返回数值大小 function calculateFontSize() { var baseSize = isPhone ? 12 : 3 , // 基数 baseWidth = 375 , //量取值大小 winw = document.documentElement.clientWidth , fontSize = ((winw / baseWidth) * baseSize).toFixed(2); document.getElementsByTagName('html')[0].style.fontSize = fontSize + 'px'; return fontSize; } $(window).resize(function () { calculateFontSize(); }); (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) { 'use strict'; var _View = require('./view360'); var _View2 = _interopRequireDefault(_View); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } //maybe var imgsize = new Image(); // 邵根 imgsize.src = imgURL + '/0001.' + m_info.houzui; // 修改 图片 宽高 // const myWidth = window.innerWidth // const myHeight = window.innerHeight // imgsize.onload = function () { // console.log('---------',imgsize.width,imgsize.height); // console.log('---------222',myWidth,myHeight); // var config1 = { // container: document.getElementById('container'), // imgsURL: imgURL, // count: imgCounts, // lev1Size: { // width: myWidth, // height: myHeight, // }, // lev2Size: { // width: myWidth * 2, // height: myHeight * 2, // }, // lev3Size: { // width: myWidth * 6, // height: myHeight * 6, // }, // horizontal: myWidth < myHeight ? 8 : 12, // vertical: myWidth < myHeight ? 12 : 8, // }; // var viewer = new _View2.default(config1); // viewer.init(); // } imgsize.onload = function () { var config1 = { container: document.getElementById('container'), imgsURL: imgURL, count: imgCounts, lev1Size: { width: imgsize.width, height: imgsize.height, }, lev2Size: { width: imgsize.width * 2, height: imgsize.height * 2, }, lev3Size: { width: imgsize.width * 6, height: imgsize.height * 6, }, horizontal: imgsize.width < imgsize.height ? 8 : 12, vertical: imgsize.width < imgsize.height ? 12 : 8, }; var viewer = new _View2.default(config1); viewer.init(); } ; } , { './view360': 2 },], 2: [function (require, module, exports) { 'use strict'; Object.defineProperty(exports, '__esModule', { value: true, }); var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; } ; } )(); function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } var isWap = /Android|webOS| iPhone | iPad | iPod |BlackBerry|opera mini|opera mobile|appleWebkit.*mobile|mobile/i.test(navigator.userAgent); var View360 = (function () { function View360(config) { _classCallCheck(this, View360); this.container = config.container; this.imgsURL = config.imgsURL; this.count = config.count; this.currentFrame = 0; this.lev1Size = config.lev1Size; this.lev2Size = config.lev2Size; this.lev3Size = config.lev3Size; this._height = this.container.clientHeight; this._width = this.container.clientWidth; //宽高比比率 this.proportion = this.lev1Size.width / this.lev1Size.height; this._mainCanvas = document.createElement('canvas'); this._mainContext = this._mainCanvas.getContext('2d'); this._lev1Canvas = document.createElement('canvas'); this._lev1Context = this._lev1Canvas.getContext('2d'); this._lev2Canvas = document.createElement('canvas'); this._lev2Context = this._lev2Canvas.getContext('2d'); this._lev3Canvas = document.createElement('canvas'); this._lev3Context = this._lev3Canvas.getContext('2d'); this._helpCanvas = document.createElement('canvas'); this._helpContext = this._helpCanvas.getContext('2d'); this._lev1ImgsPath = []; this._lev2ImgsPath = []; this._lev3ImgsPath = []; this._lev1Imgs = []; this._lev2Imgs = []; this._lev3Imgs = []; //初始缩放级别 this.detai = 1; //缩放坐标值 this.dollyStart = 0; this.dollyEnd = 0; this.dollyDelta = 0; //画布初始着色点 this._starty = 0; if (isWap) { this._endx = this._width; this._endy = this._width / this.proportion; } else { this._endx = this._height * this.proportion; this._endy = this._height; } this.centerX = this._width / 2; this.centerY = this._height / 2; this.recordX = 0; this.recordY = 0; this.mouse = { x: 0, y: 0, _x: 0, _y: 0, deltax: 0, deltay: 0, }; this.mouseState = { down: false, move: false, }; this.handState = { zoom: true, turn: true, move: false, }; this.timer = 0; //加载级别数组判定 this.isloading2 = []; this.isloading = []; this.isloading.length = this.count; for (var i = 0; i < this.count; i++) { this.isloading[i] = 'false'; this.isloading2[i] = 'false'; } this.horizontal = config.horizontal; this.vertical = config.vertical; //console.log(this.isloading); //设置播放状态 this.autoplay = false; this.stopTime = 0; } //获取图片路径,基本不用改 // 邵根----修改图片 名字和顺序 _createClass(View360, [{ key: '_createImgsPath', value: function _createImgsPath() { for (var i = 0; i < this.count; i++) { let myName = '/000' + (i + 1) myName = myName.substr(-4) var src = `${this.imgsURL}/${myName}.${m_info.houzui}`; this._lev1ImgsPath.push(src); } // 邵根 // for (var _i = 0; _i < this.count; _i++) { // var _src = this.imgsURL + '/2/2_' + _i + '.jpg'; // this._lev2ImgsPath.push(_src); // console.log('------222'); // } // for (var _i2 = 0; _i2 < this.count; _i2++) { // var tmp = []; // var base = this.imgsURL + '/3/' + _i2 + '/3_' + _i2; // for (var j = 0; j < 96; j++) { // var url = base + '_' + j + '.jpg'; // tmp.push(url); // } // this._lev3ImgsPath.push(tmp); // console.log('------333'); // } //console.log(this._lev3ImgsPath); }, //加载一级图片 }, { key: '_loadimg', value: function _loadimg() { var _this2 = this; var lev1Promise = this._lev1ImgsPath.map(function (item) { return new Promise(function (resolve, reject) { var img = new Image(); img.src = item; img.onload = function () { myJinDu += 1 // console.log('----',myJinDu); // 总数 const baiFenBi = (myJinDu / imgCounts) * 100 + '%' document.querySelector('.lodingJindu').style.width = baiFenBi return resolve(img); } ; img.onerror = function (err) { return reject(err); } ; } ); }); Promise.all(lev1Promise).then(function (imgs) { _this2._lev1Imgs = imgs; // 邵根 console.log('加载完成!!!!'); const titDom = document.createElement('img') titDom.setAttribute('id', 'hand') titDom.setAttribute('class', 'hand') // oss路径问题 titDom.setAttribute('src', `${envUrl}img/hand.png`) document.querySelector('body').appendChild(titDom) $('.loding').css({ 'opacity': '0', 'pointer-events': 'none' }) // setTimeout(function () { // document.getElementById("hand").style.display = "none"; // }, 2000); _this2.render(); }).catch(function (err) { return console.log(err); }); }, }, { key: '_loadLev2Img', value: function _loadLev2Img() { var _this3 = this; var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; //console.log('come loading2'); var lev2Promise = new Promise(function (resolve, reject) { var img = new Image(); // 邵根 if (!_this3._lev2ImgsPath[index]) return img.src = _this3._lev2ImgsPath[index]; img.onload = function () { return resolve(img); } ; img.onerror = function (err) { return reject(err); } ; } ); lev2Promise.then(function (imgs) { _this3._lev2Imgs[index] = imgs; }).catch(function (err) { return console.log(err); }); }, }, { key: '_loadLev3Img', value: function _loadLev3Img() { var _this4 = this; var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; var lev3Promise = this._lev3ImgsPath[index].map(function (item) { return new Promise(function (resolve, reject) { var img = new Image(); img.src = item; img.onload = function () { return resolve(img); } ; img.onerror = function (err) { return reject(err); } ; } ); }); Promise.all(lev3Promise).then(function (imgs) { var offsetW = 0; var offsetWs = []; var offsetH = 0; var offsetHs = []; var counts = 0; for (var i = 1; i <= _this4.vertical; i++) { offsetH += imgs[i * _this4.horizontal - 1].height; offsetW = 0; for (var j = 1; j <= _this4.horizontal; j++) { counts++; offsetW += imgs[1 * j - 1].width; //console.log(this._helpCanvas.width, this._helpCanvas.height); offsetHs.push(offsetH - imgs[i * _this4.horizontal - 1].height); offsetWs.push(offsetW - imgs[1 * j - 1].width); var m = counts - 1; _this4._helpContext.drawImage(imgs[m], offsetWs[m] / 2, offsetHs[m] / 2, imgs[m].width / 2, imgs[m].height / 2); } } var _img = new Image(); _img.src = _this4._helpCanvas.toDataURL(); _img.onload = function () { _this4._lev3Imgs[index] = _img; } ; }); }, }, { key: 'init', value: function init() { //创建相应的功能按钮,左右切换 var btn = document.createElement('div'); btn.setAttribute('class', 'btn'); if ('ontouchstart' in window) {// let fanhui = document.createElement('div'); // fanhui.setAttribute('class', 'fanhui dir'); // btn.appendChild(fanhui); } else { var left = document.createElement('div'); var right = document.createElement('div'); left.setAttribute('class', 'left dir'); right.setAttribute('class', 'right dir'); btn.appendChild(left); btn.appendChild(right); } document.body.appendChild(btn); //创建播放按钮 var playBtn = document.createElement('div'); playBtn.setAttribute('class', 'playBtn play'); btn.appendChild(playBtn); if (isPhone) { // $('.btn').hide(); document.getElementsByClassName('btn')[0].style.display = 'none'; } this._mainCanvas.width = this._width; this._mainCanvas.height = this._height; this._lev1Canvas.width = this.lev1Size.width; this._lev1Canvas.height = this.lev1Size.height; this._lev2Canvas.width = this.lev2Size.width; this._lev2Canvas.height = this.lev2Size.height; this._lev3Canvas.width = this.lev3Size.width; this._lev3Canvas.height = this.lev3Size.height; this._helpCanvas.width = this.lev3Size.width / 2; this._helpCanvas.height = this.lev3Size.height / 2; this.container.appendChild(this._mainCanvas); this._createImgsPath(); this._loadimg(); this.eventHandler(); this.startTimes(); }, }, { key: 'drawLev1Img', value: function drawLev1Img() { var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; var img = this._lev1Imgs[index]; this._lev1Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height); return { canvas: this._lev1Canvas, width: img.width, height: img.height, }; }, }, { key: 'drawLev2Img', value: function drawLev2Img() { var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; var img = this._lev2Imgs[index]; this._lev2Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height); return { canvas: this._lev2Canvas, width: img.width, height: img.height, }; }, }, { key: 'drawLev3Img', value: function drawLev3Img() { var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; var img = this._lev3Imgs[index]; this._lev3Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height); return { canvas: this._lev3Canvas, width: img.width, height: img.height, }; }, }, { key: 'mainDraw', value: function mainDraw(canvas, sx, sy, sw, sh, x, y, w, h) { this._mainContext.clearRect(0, 0, this._width, this._height); this._mainContext.drawImage(canvas, sx, sy, sw, sh, x, y, w, h); }, }, { key: 'stopTimes', value: function stopTimes() { clearTimeout(this.stopTime); this.startTimes(); }, }, { key: 'startTimes', value: function startTimes() { this.stopTime = setTimeout(function () { parent.closeIFrame(); }, 18000); }, }, { key: 'eventHandler', value: function eventHandler() { var _this5 = this; var mousewheelevt = /Firefox/i.test(navigator.userAgent) ? 'DOMMouseScroll' : 'mousewheel'; var _this = this; var dir = { left: false, right: false, }; var onmouseDown = function onmouseDown(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.down = true; _this.recordX = _this.centerX; _this.recordY = _this.centerY; if (event.button == 0) { _this.mouse._x = event.clientX; _this.mouse._y = event.clientY; } _this._mainCanvas.addEventListener('mousemove', onmouseMove, false); _this._mainCanvas.addEventListener('mouseup', onmouseUp, false); }; var onmouseMove = function onmouseMove(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.move = true; _this.mouse.x = event.clientX; _this.mouse.y = event.clientY; _this.mouse.deltax = event.clientX - _this.mouse._x; _this.mouse.deltay = event.clientY - _this.mouse._y; if (_this.detai == 1) { _this.centerX = _this._width / 2; _this.centerY = _this._height / 2; } else { _this.centerX = _this.recordX + _this.mouse.deltax; _this.centerY = _this.recordY + _this.mouse.deltay; } if (!_this.autoplay) { var deltax = event.movementX; dir.left = deltax > 0; //true 向右 dir.right = deltax < 0; _this.turn(dir); } }; var onmouseWheel = function onmouseWheel(event) { event.preventDefault(); event.stopPropagation(); var wheelDir = (event.wheelDelta || -event.detail) > 0 ? 1 : 0; //0 down 小 1 up 大 _this.zoom(wheelDir, { x: event.clientX, y: event.clientY }); }; var onmouseUp = function onmouseUp(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.down = false; if (_this.detai == 1) { _this.recordX = _this._width / 2; _this.recordY = _this._height / 2; } else { _this.recordX = _this.centerX; _this.recordY = _this.centerY; } dir.left = false; dir.right = false; _this._mainCanvas.removeEventListener('mousemove', onmouseMove, false); _this._mainCanvas.removeEventListener('mouseup', onmouseUp, false); }; var onWindowResize = function onWindowResize(event) { window.location.reload(); }; var onTouchstart = function onTouchstart(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.down = true; _this.recordX = _this.centerX; _this.recordY = _this.centerY; if (event.touches.length == 1) { _this.mouse._x = event.changedTouches[0].clientX; _this.mouse._y = event.changedTouches[0].clientY; _this.mouse.x = event.changedTouches[0].clientX; _this.mouse.y = event.changedTouches[0].clientY; } else if (event.touches.length == 2) { var dx = event.touches[0].clientX - event.touches[1].clientX; var dy = event.touches[0].clientY - event.touches[1].clientY; var distance = Math.sqrt(dx * dx + dy * dy); _this.dollyStart = distance; } _this._mainCanvas.addEventListener('touchmove', onTouchmove, false); _this._mainCanvas.addEventListener('touchend', onTouchend, false); _this.stopTimes(); // _this.render(); }; var onTouchmove = function onTouchmove(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.move = true; if (event.touches.length == 1) { _this.mouse.deltax = event.touches[0].clientX - _this.mouse._x; _this.mouse.deltay = event.touches[0].clientY - _this.mouse._y; if (_this.detai == 1) { _this.centerX = _this._width / 2; _this.centerY = _this._height / 2; } else { _this.centerX = _this.recordX + event.touches[0].clientX - _this.mouse.x; _this.centerY = _this.recordY + event.touches[0].clientY - _this.mouse.y; } // console.log(_this.centerX); _this.mouse._x = event.changedTouches[0].clientX; _this.mouse._y = event.changedTouches[0].clientY; if (!_this.autoplay) { var deltax = _this.mouse.deltax; dir.left = deltax > 0; //true 向右 dir.right = deltax < 0; _this.turn(dir); } } else { var dx = event.touches[0].clientX - event.touches[1].clientX; var dy = event.touches[0].clientY - event.touches[1].clientY; var distance = Math.sqrt(dx * dx + dy * dy); _this.dollyEnd = distance; _this.dollyDelta = _this.dollyEnd - _this.dollyStart; _this.dollyStart = _this.dollyEnd; if (_this.dollyDelta > 0.5) { _this.zoom(1, { x: _this.centerX, y: _this.centerY }); } else if (_this.dollyDelta < -0.5) { _this.zoom(0, { x: _this.centerX, y: _this.centerY }); } } _this.stopTimes(); }; var onTouchend = function onTouchend(event) { event.preventDefault(); event.stopPropagation(); _this.mouseState.down = false; dir.left = false; dir.right = false; if (_this.detai == 1) { _this.recordX = _this._width / 2; _this.recordY = _this._height / 2; } else { _this.recordX = _this.centerX; _this.recordY = _this.centerY; } _this._mainCanvas.removeEventListener('touchmove', onTouchmove, false); _this._mainCanvas.removeEventListener('touchend', onTouchend, false); _this.stopTimes(); }; if ('ontouchstart' in window) { this._mainCanvas.addEventListener('touchstart', onTouchstart, false); } else { this._mainCanvas.addEventListener('mousedown', onmouseDown, false); } document.oncontextmenu = function () { return false; } ; //兼容wheel事件 if (document.attachEvent) { document.attachEvent('on' + mousewheelevt, ommouseWheel); } else { this._mainCanvas.addEventListener(mousewheelevt, onmouseWheel, { passive: true, }); } // 邵根 // document.getElementsByClassName('playBtn')[0].addEventListener('click', function () { // if (!_this5.autoplay) { // document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn stop'); // _this5.autoplay = true; // } else { // document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn play'); // _this5.autoplay = false; // } // _this.stopTimes(); // }); // document.getElementsByClassName('pplayBtn')[0].addEventListener('click', function () { // if (!_this5.autoplay) { // document.getElementsByClassName('pplayBtn')[0].setAttribute('class', 'pplayBtn stop'); // _this5.autoplay = true; // } else { // document.getElementsByClassName('pplayBtn')[0].setAttribute('class', 'pplayBtn play'); // _this5.autoplay = false; // } // _this.stopTimes(); // }); // if ('ontouchstart' in window) { } else { // document.getElementsByClassName('right')[0].addEventListener('click', function () { // _this5.currentFrame--; // }); // document.getElementsByClassName('left')[0].addEventListener('click', function () { // _this5.currentFrame++; // }); // } window.addEventListener('resize', onWindowResize, false); }, }, { key: 'render', value: function render() { // 邵根 -- 当前滑动的图片是第几张 // console.log('----当前滑动的图片---', this.currentFrame, this.count); var _this6 = this; this.timer++; //重置当前Frame this.currentFrame = this.currentFrame >= this.count ? 0 : this.currentFrame < 0 ? this.count - 1 : this.currentFrame; var param = this.drawLev1Img(this.currentFrame); if (this.isloading2[this.currentFrame] == 'false') { this.isloading2[this.currentFrame] = 'true'; this._loadLev2Img(this.currentFrame); } //按需加载 if (this.isloading[this.currentFrame] == 'false' && this.detai >= 8) { this.isloading[this.currentFrame] = 'true'; } if (this._lev2Imgs[this.currentFrame]) { param = this.drawLev2Img(this.currentFrame); } if (this._lev3Imgs[this.currentFrame]) { param = this.drawLev3Img(this.currentFrame); } //--开始剪切的起始位置 --被剪切图像的宽高 --在画布上放置的图像的起始位置 --使用的图像的宽高 this.mainDraw(param.canvas, 0, 0, param.width, param.height, this.centerX - this._endx / 2, this.centerY - this._endy / 2, this._endx, this._endy); requestAnimationFrame(function () { _this6.render(); }); if (this.autoplay && this.handState.turn) { this.centerX = this._width / 2; this.centerY = this._height / 2; this.detai = 1; this.handState.zoom = false; if (isWap) { this._endx = this._width; this._endy = this._width / this.proportion; } else { this._endx = this._height * this.proportion; this._endy = this._height; } if (this.timer % 30 === 0) this.currentFrame++; } else { this.handState.zoom = true; } }, //左右转向 }, { key: 'turn', value: function turn(dir) { if (!this.handState.turn) return; if (dir.left && this.mouseState.down && this.detai < 2) { // console.log('左滑倒退', this.currentFrame); if (this.currentFrame <= 0) this.currentFrame = 0 else this.currentFrame--; } if (dir.right && this.mouseState.down && this.detai < 2) { // console.log('右滑前进', this.currentFrame); if (this.currentFrame >= imgCounts - 1) this.currentFrame = imgCounts - 1 else this.currentFrame++; } // this.currentFrame >= this.count ? this.currentFrame = 0 : (this.currentFrame < 0 ? this.currentFrame = imgCounts : this.currentFrame); // 邵根 -滚动条 const nowImgNum = this.currentFrame + 1 console.log('-当前滚动到的图片:', nowImgNum); let nowGunBai = (nowImgNum / imgCounts) * 100 document.querySelector('.gunDongDomSon').style.top = nowGunBai + '%' }, //轮滑缩放 }, { key: 'zoom', value: function zoom(dir, pos) { if (!this.handState.zoom) return; if (dir > 0) { this.detai += 1; var maxdetai = 15; this.detai <= maxdetai ? this.detai : (this.detai = maxdetai); if (this.detai < maxdetai) { this._endx = this._endx * 1.1; this._endy = this._endy * 1.1; } else { this._endx = this._endx; this._endy = this._endy; } if (this.detai < 15) { this.centerX = pos.x + (this.centerX - pos.x) * 1.1; this.centerY = pos.y - (pos.y - this.centerY) * 1.1; } else { // this.centerX = pos.x + (this._width / 2 - pos.x) * Math.pow(1.1, 14); // this.centerY = pos.y - (pos.y - this._height / 2) * Math.pow(1.1, 14); this.centerX = this.centerX; this.centerY = this.centerY; } } else { this.detai += -1; var mindetai = 1; this.detai >= mindetai ? this.detai : (this.detai = mindetai); if (this.detai > mindetai) { this._endx = this._endx / 1.1; this._endy = this._endy / 1.1; } else { if (isWap) { this._endx = this._width; this._endy = this._width / this.proportion; } else { this._endx = this._height * this.proportion; this._endy = this._height; } } if (this.detai == 1) { this.centerX = this._width / 2; this.centerY = this._height / 2; } else { this.centerX = pos.x + (this.centerX - pos.x) * 0.9; this.centerY = pos.y - (pos.y - this.centerY) * 0.9; } } }, },]); return View360; } )(); exports.default = View360; } , {},], }, {}, [1]); //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","src/app.js","src/script/View360.js"],"names":[],"mappings":"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","file":"bundle3.js","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})()","import View360 from './script/View360';\r\n\r\n\r\n//maybe\r\nconst imgsize = new Image();\r\nimgsize.src = imgURL + '/1/1_0.jpg';\r\nimgsize.onload = function() {\r\n    const config1 = {\r\n        container: document.getElementById('container'),\r\n        imgsURL: imgURL,\r\n        count: imgCounts,\r\n        lev1Size: {\r\n            width: imgsize.width,\r\n            height: imgsize.height\r\n        },\r\n        lev2Size: {\r\n            width: imgsize.width * 2,\r\n            height: imgsize.height * 2\r\n        },\r\n        lev3Size: {\r\n            width: imgsize.width * 6,\r\n            height: imgsize.height * 6\r\n        },\r\n        horizontal: imgsize.width < imgsize.height ? 8 : 12,\r\n        vertical: imgsize.width < imgsize.height ? 12 : 8,\r\n    };\r\n    const viewer = new View360(config1);\r\n    viewer.init();\r\n}","\r\nvar isWap = /Android|webOS| iPhone | iPad | iPod |BlackBerry|opera mini|opera mobile|appleWebkit.*mobile|mobile/i.test(navigator.userAgent);\r\n\r\nclass View360 {\r\n    constructor(config) {\r\n        this.container = config.container;\r\n        this.imgsURL = config.imgsURL;\r\n        this.count = config.count;\r\n        this.currentFrame = 0;\r\n\r\n        this.lev1Size = config.lev1Size;\r\n        this.lev2Size = config.lev2Size;\r\n        this.lev3Size = config.lev3Size;\r\n\r\n        this._height = this.container.clientHeight;\r\n        this._width = this.container.clientWidth;\r\n\r\n        //宽高比比率\r\n        this.proportion = this.lev1Size.width / this.lev1Size.height;\r\n        this._mainCanvas = document.createElement('canvas');\r\n        this._mainContext = this._mainCanvas.getContext('2d');\r\n\r\n        this._lev1Canvas = document.createElement('canvas');\r\n        this._lev1Context = this._lev1Canvas.getContext('2d');\r\n\r\n        this._lev2Canvas = document.createElement('canvas');\r\n        this._lev2Context = this._lev2Canvas.getContext('2d');\r\n\r\n        this._lev3Canvas = document.createElement('canvas');\r\n        this._lev3Context = this._lev3Canvas.getContext('2d');\r\n\r\n        this._helpCanvas = document.createElement('canvas');\r\n        this._helpContext = this._helpCanvas.getContext('2d');\r\n\r\n        this._lev1ImgsPath = [];\r\n        this._lev2ImgsPath = [];\r\n        this._lev3ImgsPath = [];\r\n        this._lev1Imgs = [];\r\n        this._lev2Imgs = [];\r\n        this._lev3Imgs = [];\r\n\r\n        //初始缩放级别\r\n        this.detai = 1;\r\n\r\n        //缩放坐标值\r\n        this.dollyStart = 0;\r\n        this.dollyEnd = 0;\r\n        this.dollyDelta = 0;\r\n\r\n        //画布初始着色点\r\n        this._starty = 0;\r\n\r\n        if (isWap) {\r\n            this._endx = this._width;\r\n            this._endy = this._width / this.proportion;\r\n        } else {\r\n            this._endx = this._height * this.proportion;\r\n            this._endy = this._height;    \r\n        }\r\n        \r\n\r\n        this.centerX = this._width / 2;\r\n        this.centerY = this._height / 2;\r\n\r\n        this.recordX = 0;\r\n        this.recordY = 0;\r\n\r\n        this.mouse = {\r\n            x: 0,\r\n            y: 0,\r\n            _x: 0,\r\n            _y: 0,\r\n            deltax: 0,\r\n            deltay: 0,\r\n        };\r\n\r\n        this.mouseState = {\r\n            down: false,\r\n            move: false\r\n        };\r\n        this.handState = {\r\n            zoom: true,\r\n            turn: true,\r\n            move: false\r\n        };\r\n        this.timer = 0;\r\n\r\n        //加载级别数组判定\r\n        this.isloading2 = [];\r\n        this.isloading = [];\r\n        this.isloading.length = this.count;\r\n        for (let i = 0; i < this.count; i++) {\r\n            this.isloading[i] = 'false';\r\n            this.isloading2[i] = 'false';\r\n        }\r\n        this.horizontal = config.horizontal;\r\n        this.vertical = config.vertical;\r\n        //console.log(this.isloading);\r\n        //设置播放状态\r\n        this.autoplay = false;\r\n\r\n        this.stopTime = 0;\r\n    }\r\n\r\n    //获取图片路径，基本不用改\r\n    _createImgsPath() {\r\n        for (let i = 0; i < this.count; i++) {\r\n            let src = this.imgsURL + '/1/1_' + i + '.jpg';\r\n            this._lev1ImgsPath.push(src);\r\n        }\r\n        for (let i = 0; i < this.count; i++) {\r\n            let src = this.imgsURL + '/2/2_' + i + '.jpg';\r\n            this._lev2ImgsPath.push(src);\r\n        }\r\n        for (let i = 0; i < this.count; i++) {\r\n            let tmp = [];\r\n            let base = this.imgsURL + '/3/' + i + '/3_' + i;\r\n            for (let j = 0; j < 96; j++) {\r\n                let url = base + '_' + j + '.jpg';\r\n                tmp.push(url);\r\n            }\r\n            this._lev3ImgsPath.push(tmp);\r\n\r\n        }\r\n        //console.log(this._lev3ImgsPath);\r\n    }\r\n\r\n    //加载一级图片\r\n    _loadimg() {\r\n      \r\n        const lev1Promise = this._lev1ImgsPath.map((item) => {\r\n            return new Promise(function (resolve, reject) {\r\n                const img = new Image();\r\n                img.src = item;\r\n                img.onload = () => resolve(img);\r\n                img.onerror = (err) => reject(err);\r\n            });\r\n        });\r\n\r\n        Promise.all(lev1Promise)\r\n            .then((imgs) => {\r\n                this._lev1Imgs = imgs;\r\n                this.render();\r\n            })\r\n            .catch((err) => console.log(err));\r\n    }\r\n\r\n    _loadLev2Img(index = 0) {\r\n        //console.log('come loading2');\r\n        let lev2Promise = new Promise((resolve, reject) => {\r\n            const img = new Image();\r\n            img.src = this._lev2ImgsPath[index];\r\n            img.onload = () => resolve(img);\r\n            img.onerror = (err) => reject(err);\r\n        });\r\n\r\n\r\n        lev2Promise.then((imgs) => {\r\n            this._lev2Imgs[index] = imgs;\r\n        })\r\n            .catch((err) => console.log(err));\r\n    }\r\n\r\n    _loadLev3Img(index = 0) {\r\n\r\n        var lev3Promise = this._lev3ImgsPath[index].map((item) => {\r\n            return new Promise((resolve, reject) => {\r\n                const img = new Image();\r\n                img.src = item;\r\n                img.onload = () => resolve(img);\r\n                img.onerror = (err) => reject(err);\r\n            });\r\n        });\r\n        Promise.all(lev3Promise)\r\n            .then((imgs) => {\r\n                let offsetW = 0;\r\n                let offsetWs = [];\r\n                let offsetH = 0;\r\n                let offsetHs = [];\r\n                let counts = 0;\r\n                for (var i = 1; i <= this.vertical; i++) {\r\n\r\n                    offsetH += imgs[i * this.horizontal - 1].height;\r\n                    offsetW = 0;\r\n                    for (var j = 1; j <= this.horizontal; j++) {\r\n                        counts++;\r\n                        offsetW += imgs[1 * j - 1].width;\r\n                        //console.log(this._helpCanvas.width, this._helpCanvas.height);\r\n\r\n                        offsetHs.push(offsetH - imgs[i * this.horizontal - 1].height);\r\n                        offsetWs.push(offsetW - imgs[1 * j - 1].width);\r\n                        let m = counts - 1;\r\n                        this._helpContext.drawImage(imgs[m], offsetWs[m] / 2, offsetHs[m] / 2, imgs[m].width / 2, imgs[m].height / 2);\r\n                    }\r\n\r\n\r\n                }\r\n\r\n                const _img = new Image();\r\n                _img.src = this._helpCanvas.toDataURL();\r\n                _img.onload = () => {\r\n                    this._lev3Imgs[index] = _img;\r\n\r\n                };\r\n\r\n            });\r\n    }\r\n    init() {\r\n        //创建相应的功能按钮,左右切换\r\n        let btn = document.createElement('div');\r\n        btn.setAttribute('class', 'btn');\r\n        if ('ontouchstart' in window) {\r\n            // let fanhui = document.createElement('div');\r\n            // fanhui.setAttribute('class', 'fanhui dir');\r\n            // btn.appendChild(fanhui);\r\n        } else {\r\n            let left = document.createElement('div');\r\n            let right = document.createElement('div');\r\n            left.setAttribute('class', 'left dir');\r\n            right.setAttribute('class', 'right dir');\r\n            btn.appendChild(left);\r\n            btn.appendChild(right);\r\n        }\r\n\r\n        document.body.appendChild(btn);\r\n\r\n        //创建播放按钮\r\n        let playBtn = document.createElement('div');\r\n        playBtn.setAttribute('class', 'playBtn play');\r\n        btn.appendChild(playBtn);\r\n\r\n        this._mainCanvas.width = this._width;\r\n        this._mainCanvas.height = this._height;\r\n        this._lev1Canvas.width = this.lev1Size.width;\r\n        this._lev1Canvas.height = this.lev1Size.height;\r\n        this._lev2Canvas.width = this.lev2Size.width;\r\n        this._lev2Canvas.height = this.lev2Size.height;\r\n        this._lev3Canvas.width = this.lev3Size.width;\r\n        this._lev3Canvas.height = this.lev3Size.height;\r\n        this._helpCanvas.width = this.lev3Size.width / 2;\r\n        this._helpCanvas.height = this.lev3Size.height / 2;\r\n\r\n        this.container.appendChild(this._mainCanvas);\r\n\r\n        this._createImgsPath();\r\n        this._loadimg();\r\n        this.eventHandler();\r\n        this.startTimes();\r\n\r\n    }\r\n    drawLev1Img(index = 0) {\r\n        const img = this._lev1Imgs[index];\r\n       \r\n        this._lev1Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev1Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    drawLev2Img(index = 0) {\r\n        const img = this._lev2Imgs[index];\r\n       \r\n        this._lev2Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev2Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    drawLev3Img(index = 0) {\r\n        const img = this._lev3Imgs[index];\r\n       \r\n        this._lev3Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev3Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    mainDraw(canvas, sx, sy, sw, sh, x, y, w, h) {\r\n       \r\n        this._mainContext.clearRect(0, 0, this._width, this._height);\r\n\r\n            this._mainContext.drawImage(canvas, sx, sy, sw, sh, x, y, w, h);\r\n      \r\n    }\r\n\r\n    stopTimes() {\r\n        clearTimeout(this.stopTime);\r\n        this.startTimes();\r\n    }\r\n\r\n    startTimes() {\r\n        this.stopTime = setTimeout(() => {\r\n            parent.closeIFrame();\r\n        }, 18000);\r\n    }\r\n\r\n\r\n    eventHandler() {\r\n        let mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? \"DOMMouseScroll\" : \"mousewheel\";\r\n        const _this = this;\r\n        const dir = {\r\n            left: false,\r\n            right: false\r\n        }\r\n        const onmouseDown = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = true;\r\n\r\n            _this.recordX = _this.centerX;\r\n            _this.recordY = _this.centerY;\r\n\r\n            if (event.button == 0) {\r\n                _this.mouse._x = event.clientX;\r\n                _this.mouse._y = event.clientY;\r\n\r\n            }\r\n\r\n            _this._mainCanvas.addEventListener('mousemove', onmouseMove, false);\r\n            _this._mainCanvas.addEventListener('mouseup', onmouseUp, false);\r\n     \r\n\r\n        }\r\n        const onmouseMove = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.move = true;\r\n            _this.mouse.x = event.clientX;\r\n            _this.mouse.y = event.clientY;\r\n\r\n            _this.mouse.deltax = event.clientX - _this.mouse._x;\r\n            _this.mouse.deltay = event.clientY - _this.mouse._y;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.centerX = _this._width / 2;\r\n                _this.centerY = _this._height / 2;\r\n            } else {\r\n                _this.centerX = _this.recordX + _this.mouse.deltax;\r\n                _this.centerY = _this.recordY + _this.mouse.deltay;\r\n            }\r\n\r\n            if (!_this.autoplay) {\r\n                let deltax = event.movementX;\r\n\r\n                console.log(event.movementX);\r\n\r\n                dir.left = deltax > 0; //true 向右\r\n                dir.right = deltax < 0;\r\n\r\n                _this.turn(dir);\r\n            }\r\n          \r\n        }\r\n\r\n        const onmouseWheel = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            const wheelDir = (event.wheelDelta || -event.detail) > 0 ? 1 : 0; //0  down 小 1 up 大\r\n            _this.zoom(wheelDir, { x: event.clientX, y: event.clientY });\r\n\r\n        }\r\n        const onmouseUp = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = false;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.recordX = _this._width / 2;\r\n                _this.recordY = _this._height / 2;\r\n            } else {\r\n                _this.recordX = _this.centerX;\r\n                _this.recordY = _this.centerY;\r\n            }\r\n\r\n\r\n            dir.left = false;\r\n            dir.right = false;\r\n\r\n            _this._mainCanvas.removeEventListener('mousemove', onmouseMove, false);\r\n            _this._mainCanvas.removeEventListener('mouseup', onmouseUp, false);\r\n\r\n        }\r\n        const onWindowResize = function (event) {\r\n            window.location.reload();\r\n          \r\n\r\n        }\r\n\r\n        const onTouchstart = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = true;\r\n\r\n            _this.recordX = _this.centerX;\r\n            _this.recordY = _this.centerY;\r\n\r\n            if (event.touches.length == 1) {\r\n\r\n                _this.mouse._x = event.changedTouches[0].clientX;\r\n                _this.mouse._y = event.changedTouches[0].clientY;\r\n                _this.mouse.x = event.changedTouches[0].clientX;\r\n                _this.mouse.y = event.changedTouches[0].clientY;\r\n\r\n            } else if (event.touches.length == 2) {\r\n\r\n                let dx = event.touches[0].clientX - event.touches[1].clientX;\r\n                let dy = event.touches[0].clientY - event.touches[1].clientY;\r\n\r\n                let distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n                _this.dollyStart = distance;\r\n            }\r\n\r\n            _this._mainCanvas.addEventListener('touchmove', onTouchmove, false);\r\n            _this._mainCanvas.addEventListener('touchend', onTouchend, false);\r\n            _this.stopTimes();\r\n            // _this.render();\r\n        }\r\n\r\n        const onTouchmove = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.move = true;\r\n            if (event.touches.length == 1) {\r\n\r\n                _this.mouse.deltax = event.touches[0].clientX - _this.mouse._x;\r\n                _this.mouse.deltay = event.touches[0].clientY - _this.mouse._y;\r\n\r\n                if (_this.detai == 1) {\r\n                    _this.centerX = _this._width / 2;\r\n                    _this.centerY = _this._height / 2;\r\n                } else {\r\n                    _this.centerX = _this.recordX + event.touches[0].clientX - _this.mouse.x;\r\n                    _this.centerY = _this.recordY + event.touches[0].clientY - _this.mouse.y;\r\n                }\r\n\r\n                console.log(_this.centerX)\r\n\r\n                _this.mouse._x = event.changedTouches[0].clientX;\r\n                _this.mouse._y = event.changedTouches[0].clientY;\r\n\r\n                if (!_this.autoplay) {\r\n                  \r\n                    var deltax = _this.mouse.deltax;\r\n\r\n                    dir.left = deltax > 0; //true 向右\r\n                    dir.right = deltax < 0;\r\n\r\n                    _this.turn(dir);\r\n                    \r\n\r\n                }\r\n\r\n            } else {\r\n                var dx = event.touches[0].clientX - event.touches[1].clientX;\r\n                var dy = event.touches[0].clientY - event.touches[1].clientY;\r\n\r\n                var distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n                _this.dollyEnd = distance;\r\n\r\n                _this.dollyDelta = _this.dollyEnd - _this.dollyStart;\r\n\r\n                _this.dollyStart = _this.dollyEnd;\r\n\r\n\r\n                if (_this.dollyDelta > 0.5) {\r\n                   \r\n                    _this.zoom(1, { x: _this.centerX, y: _this.centerY } );\r\n \r\n                } else if(_this.dollyDelta < -0.5) {\r\n                \r\n                    _this.zoom(0, { x: _this.centerX, y: _this.centerY } );\r\n                  \r\n                }\r\n               \r\n            }\r\n            _this.stopTimes();\r\n            \r\n        }\r\n\r\n        const onTouchend = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = false;\r\n            dir.left = false;\r\n            dir.right = false;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.recordX = _this._width / 2;\r\n                _this.recordY = _this._height / 2;\r\n            } else {\r\n                _this.recordX = _this.centerX;\r\n                _this.recordY = _this.centerY;\r\n            }\r\n\r\n\r\n            _this._mainCanvas.removeEventListener('touchmove', onTouchmove, false);\r\n            _this._mainCanvas.removeEventListener('touchend', onTouchend, false);\r\n            _this.stopTimes();\r\n        }\r\n\r\n        if ('ontouchstart' in window) {\r\n            this._mainCanvas.addEventListener('touchstart', onTouchstart, false);\r\n           \r\n        } else {\r\n            this._mainCanvas.addEventListener('mousedown', onmouseDown, false);\r\n          \r\n        }\r\n\r\n        document.oncontextmenu = function () {\r\n            return false;\r\n        }\r\n\r\n        //兼容wheel事件\r\n        if (document.attachEvent) {\r\n            document.attachEvent('on' + mousewheelevt, ommouseWheel);\r\n        } else {\r\n            this._mainCanvas.addEventListener(mousewheelevt, onmouseWheel, {\r\n                passive: true\r\n            });\r\n\r\n        }\r\n\r\n        document.getElementsByClassName('playBtn')[0].addEventListener('click', () => {\r\n            if (!this.autoplay) {\r\n                document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn stop');\r\n                this.autoplay = true;\r\n            } else {\r\n                document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn play');\r\n                this.autoplay = false;\r\n            }\r\n\r\n            _this.stopTimes();\r\n        });\r\n        if ('ontouchstart' in window) {\r\n            \r\n        } else {\r\n            document.getElementsByClassName('right')[0].addEventListener('click', () => {\r\n                this.currentFrame--;\r\n            });\r\n            document.getElementsByClassName('left')[0].addEventListener('click', () => {\r\n                this.currentFrame++;\r\n            })\r\n        }\r\n\r\n        window.addEventListener('resize', onWindowResize, false);\r\n    }\r\n    render() {\r\n        this.timer++;\r\n        //重置当前Frame\r\n        this.currentFrame = this.currentFrame >= this.count ? 0 : (this.currentFrame < 0 ? this.count - 1 : this.currentFrame);\r\n        let param = this.drawLev1Img(this.currentFrame);\r\n        if (this.isloading2[this.currentFrame] == 'false') {\r\n            this.isloading2[this.currentFrame] = 'true';\r\n            this._loadLev2Img(this.currentFrame);\r\n        }\r\n\r\n        //按需加载\r\n        if (this.isloading[this.currentFrame] == 'false' && this.detai >= 8) {\r\n            this.isloading[this.currentFrame] = 'true';\r\n            !isWap && this._loadLev3Img(this.currentFrame);\r\n        }\r\n\r\n\r\n        if (this._lev2Imgs[this.currentFrame]) {\r\n            param = this.drawLev2Img(this.currentFrame);\r\n        }\r\n        if (this._lev3Imgs[this.currentFrame]) {\r\n            param = this.drawLev3Img(this.currentFrame);\r\n        }\r\n\r\n        //--开始剪切的起始位置 --被剪切图像的宽高 --在画布上放置的图像的起始位置 --使用的图像的宽高\r\n\r\n        this.mainDraw(param.canvas, 0, 0, param.width, param.height, this.centerX - this._endx / 2, this.centerY - this._endy / 2, this._endx, this._endy);\r\n       \r\n\r\n        requestAnimationFrame(() => {\r\n            this.render()\r\n        });\r\n\r\n\r\n        if (this.autoplay && this.handState.turn) {\r\n            this.centerX = this._width / 2;\r\n            this.centerY = this._height / 2;\r\n            this.detai = 1;\r\n            this.handState.zoom = false;\r\n            if (isWap) {\r\n                this._endx = this._width;\r\n                this._endy = this._width / this.proportion;\r\n            } else {\r\n                this._endx = this._height * this.proportion;\r\n                this._endy = this._height;    \r\n            }\r\n            if (this.timer % (30) === 0) this.currentFrame++;\r\n        } else {\r\n            this.handState.zoom = true;\r\n        }\r\n\r\n\r\n\r\n    }\r\n\r\n    //左右转向\r\n    turn(dir) {\r\n        if (!this.handState.turn) return;\r\n        if (dir.left && this.mouseState.down && this.detai < 2) {\r\n\r\n            this.currentFrame--;\r\n\r\n        }\r\n        if (dir.right && this.mouseState.down && this.detai < 2) {\r\n\r\n            this.currentFrame++;\r\n\r\n        }\r\n        // this.currentFrame >= this.count ? this.currentFrame = 0 : (this.currentFrame < 0 ? this.currentFrame = 44 : this.currentFrame);\r\n\r\n    }\r\n\r\n    //轮滑缩放\r\n    zoom(dir, pos) {\r\n        if (!this.handState.zoom) return;\r\n        if (dir > 0) {\r\n            this.detai += 1;\r\n            let maxdetai = 15;\r\n            this.detai <= maxdetai ? this.detai : this.detai = maxdetai;\r\n            if (this.detai < maxdetai) {\r\n                this._endx = this._endx * 1.1;\r\n                this._endy = this._endy * 1.1;\r\n            } else {\r\n                this._endx = this._endx;\r\n                this._endy = this._endy;\r\n            }\r\n            if (this.detai < 15) {\r\n                this.centerX = pos.x + (this.centerX - pos.x) * 1.1;\r\n                this.centerY = pos.y - (pos.y - this.centerY) * 1.1;\r\n            } else {\r\n                // this.centerX = pos.x + (this._width / 2 - pos.x) * Math.pow(1.1, 14);\r\n                // this.centerY = pos.y - (pos.y - this._height / 2) * Math.pow(1.1, 14);\r\n                this.centerX = this.centerX;\r\n                this.centerY = this.centerY;\r\n            }\r\n\r\n\r\n        } else {\r\n\r\n            this.detai += -1;\r\n\r\n            let mindetai = 1;\r\n            this.detai >= mindetai ? this.detai : this.detai = mindetai;\r\n\r\n\r\n            if (this.detai > mindetai) {\r\n                this._endx = this._endx / 1.1;\r\n                this._endy = this._endy / 1.1;\r\n            } else {\r\n                if (isWap) {\r\n                    this._endx = this._width;\r\n                    this._endy = this._width / this.proportion;\r\n                } else {\r\n                    this._endx = this._height * this.proportion;\r\n                    this._endy = this._height;    \r\n                }\r\n            }\r\n\r\n            if (this.detai == 1) {\r\n                this.centerX = this._width / 2;\r\n                this.centerY = this._height / 2;\r\n            } else {\r\n                this.centerX = pos.x + (this.centerX - pos.x) * 0.9;\r\n                this.centerY = pos.y - (pos.y - this.centerY) * 0.9;\r\n            }\r\n        }\r\n\r\n    }\r\n\r\n}\r\nexport default View360"],"preExistingComment":"//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","src/app.js","src/script/View360.js"],"names":[],"mappings":"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","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})()","import View360 from './script/View360';\r\n\r\n\r\n//maybe\r\nconst imgsize = new Image();\r\nimgsize.src = imgURL + '/1/1_0.jpg';\r\nimgsize.onload = function() {\r\n    const config1 = {\r\n        container: document.getElementById('container'),\r\n        imgsURL: imgURL,\r\n        count: imgCounts,\r\n        lev1Size: {\r\n            width: imgsize.width,\r\n            height: imgsize.height\r\n        },\r\n        lev2Size: {\r\n            width: imgsize.width * 2,\r\n            height: imgsize.height * 2\r\n        },\r\n        lev3Size: {\r\n            width: imgsize.width * 6,\r\n            height: imgsize.height * 6\r\n        },\r\n        horizontal: imgsize.width < imgsize.height ? 8 : 12,\r\n        vertical: imgsize.width < imgsize.height ? 12 : 8,\r\n    };\r\n    const viewer = new View360(config1);\r\n    viewer.init();\r\n}","\r\nvar isWap = /Android|webOS| iPhone | iPad | iPod |BlackBerry|opera mini|opera mobile|appleWebkit.*mobile|mobile/i.test(navigator.userAgent);\r\n\r\nclass View360 {\r\n    constructor(config) {\r\n        this.container = config.container;\r\n        this.imgsURL = config.imgsURL;\r\n        this.count = config.count;\r\n        this.currentFrame = 0;\r\n\r\n        this.lev1Size = config.lev1Size;\r\n        this.lev2Size = config.lev2Size;\r\n        this.lev3Size = config.lev3Size;\r\n\r\n        this._height = this.container.clientHeight;\r\n        this._width = this.container.clientWidth;\r\n\r\n        //宽高比比率\r\n        this.proportion = this.lev1Size.width / this.lev1Size.height;\r\n        this._mainCanvas = document.createElement('canvas');\r\n        this._mainContext = this._mainCanvas.getContext('2d');\r\n\r\n        this._lev1Canvas = document.createElement('canvas');\r\n        this._lev1Context = this._lev1Canvas.getContext('2d');\r\n\r\n        this._lev2Canvas = document.createElement('canvas');\r\n        this._lev2Context = this._lev2Canvas.getContext('2d');\r\n\r\n        this._lev3Canvas = document.createElement('canvas');\r\n        this._lev3Context = this._lev3Canvas.getContext('2d');\r\n\r\n        this._helpCanvas = document.createElement('canvas');\r\n        this._helpContext = this._helpCanvas.getContext('2d');\r\n\r\n        this._lev1ImgsPath = [];\r\n        this._lev2ImgsPath = [];\r\n        this._lev3ImgsPath = [];\r\n        this._lev1Imgs = [];\r\n        this._lev2Imgs = [];\r\n        this._lev3Imgs = [];\r\n\r\n        //初始缩放级别\r\n        this.detai = 1;\r\n\r\n        //缩放坐标值\r\n        this.dollyStart = 0;\r\n        this.dollyEnd = 0;\r\n        this.dollyDelta = 0;\r\n\r\n        //画布初始着色点\r\n        this._starty = 0;\r\n\r\n        if (isWap) {\r\n            this._endx = this._width;\r\n            this._endy = this._width / this.proportion;\r\n        } else {\r\n            this._endx = this._height * this.proportion;\r\n            this._endy = this._height;    \r\n        }\r\n        \r\n\r\n        this.centerX = this._width / 2;\r\n        this.centerY = this._height / 2;\r\n\r\n        this.recordX = 0;\r\n        this.recordY = 0;\r\n\r\n        this.mouse = {\r\n            x: 0,\r\n            y: 0,\r\n            _x: 0,\r\n            _y: 0,\r\n            deltax: 0,\r\n            deltay: 0,\r\n        };\r\n\r\n        this.mouseState = {\r\n            down: false,\r\n            move: false\r\n        };\r\n        this.handState = {\r\n            zoom: true,\r\n            turn: true,\r\n            move: false\r\n        };\r\n        this.timer = 0;\r\n\r\n        //加载级别数组判定\r\n        this.isloading2 = [];\r\n        this.isloading = [];\r\n        this.isloading.length = this.count;\r\n        for (let i = 0; i < this.count; i++) {\r\n            this.isloading[i] = 'false';\r\n            this.isloading2[i] = 'false';\r\n        }\r\n        this.horizontal = config.horizontal;\r\n        this.vertical = config.vertical;\r\n        //console.log(this.isloading);\r\n        //设置播放状态\r\n        this.autoplay = false;\r\n\r\n        this.stopTime = 0;\r\n    }\r\n\r\n    //获取图片路径，基本不用改\r\n    _createImgsPath() {\r\n        for (let i = 0; i < this.count; i++) {\r\n            let src = this.imgsURL + '/1/1_' + i + '.jpg';\r\n            this._lev1ImgsPath.push(src);\r\n        }\r\n        for (let i = 0; i < this.count; i++) {\r\n            let src = this.imgsURL + '/2/2_' + i + '.jpg';\r\n            this._lev2ImgsPath.push(src);\r\n        }\r\n        for (let i = 0; i < this.count; i++) {\r\n            let tmp = [];\r\n            let base = this.imgsURL + '/3/' + i + '/3_' + i;\r\n            for (let j = 0; j < 96; j++) {\r\n                let url = base + '_' + j + '.jpg';\r\n                tmp.push(url);\r\n            }\r\n            this._lev3ImgsPath.push(tmp);\r\n\r\n        }\r\n        //console.log(this._lev3ImgsPath);\r\n    }\r\n\r\n    //加载一级图片\r\n    _loadimg() {\r\n      \r\n        const lev1Promise = this._lev1ImgsPath.map((item) => {\r\n            return new Promise(function (resolve, reject) {\r\n                const img = new Image();\r\n                img.src = item;\r\n                img.onload = () => resolve(img);\r\n                img.onerror = (err) => reject(err);\r\n            });\r\n        });\r\n\r\n        Promise.all(lev1Promise)\r\n            .then((imgs) => {\r\n                this._lev1Imgs = imgs;\r\n                this.render();\r\n            })\r\n            .catch((err) => console.log(err));\r\n    }\r\n\r\n    _loadLev2Img(index = 0) {\r\n        //console.log('come loading2');\r\n        let lev2Promise = new Promise((resolve, reject) => {\r\n            const img = new Image();\r\n            img.src = this._lev2ImgsPath[index];\r\n            img.onload = () => resolve(img);\r\n            img.onerror = (err) => reject(err);\r\n        });\r\n\r\n\r\n        lev2Promise.then((imgs) => {\r\n            this._lev2Imgs[index] = imgs;\r\n        })\r\n            .catch((err) => console.log(err));\r\n    }\r\n\r\n    _loadLev3Img(index = 0) {\r\n\r\n        var lev3Promise = this._lev3ImgsPath[index].map((item) => {\r\n            return new Promise((resolve, reject) => {\r\n                const img = new Image();\r\n                img.src = item;\r\n                img.onload = () => resolve(img);\r\n                img.onerror = (err) => reject(err);\r\n            });\r\n        });\r\n        Promise.all(lev3Promise)\r\n            .then((imgs) => {\r\n                let offsetW = 0;\r\n                let offsetWs = [];\r\n                let offsetH = 0;\r\n                let offsetHs = [];\r\n                let counts = 0;\r\n                for (var i = 1; i <= this.vertical; i++) {\r\n\r\n                    offsetH += imgs[i * this.horizontal - 1].height;\r\n                    offsetW = 0;\r\n                    for (var j = 1; j <= this.horizontal; j++) {\r\n                        counts++;\r\n                        offsetW += imgs[1 * j - 1].width;\r\n                        //console.log(this._helpCanvas.width, this._helpCanvas.height);\r\n\r\n                        offsetHs.push(offsetH - imgs[i * this.horizontal - 1].height);\r\n                        offsetWs.push(offsetW - imgs[1 * j - 1].width);\r\n                        let m = counts - 1;\r\n                        this._helpContext.drawImage(imgs[m], offsetWs[m] / 2, offsetHs[m] / 2, imgs[m].width / 2, imgs[m].height / 2);\r\n                    }\r\n\r\n\r\n                }\r\n\r\n                const _img = new Image();\r\n                _img.src = this._helpCanvas.toDataURL();\r\n                _img.onload = () => {\r\n                    this._lev3Imgs[index] = _img;\r\n\r\n                };\r\n\r\n            });\r\n    }\r\n    init() {\r\n        //创建相应的功能按钮,左右切换\r\n        let btn = document.createElement('div');\r\n        btn.setAttribute('class', 'btn');\r\n        if ('ontouchstart' in window) {\r\n            // let fanhui = document.createElement('div');\r\n            // fanhui.setAttribute('class', 'fanhui dir');\r\n            // btn.appendChild(fanhui);\r\n        } else {\r\n            let left = document.createElement('div');\r\n            let right = document.createElement('div');\r\n            left.setAttribute('class', 'left dir');\r\n            right.setAttribute('class', 'right dir');\r\n            btn.appendChild(left);\r\n            btn.appendChild(right);\r\n        }\r\n\r\n        document.body.appendChild(btn);\r\n\r\n        //创建播放按钮\r\n        let playBtn = document.createElement('div');\r\n        playBtn.setAttribute('class', 'playBtn play');\r\n        btn.appendChild(playBtn);\r\n\r\n        this._mainCanvas.width = this._width;\r\n        this._mainCanvas.height = this._height;\r\n        this._lev1Canvas.width = this.lev1Size.width;\r\n        this._lev1Canvas.height = this.lev1Size.height;\r\n        this._lev2Canvas.width = this.lev2Size.width;\r\n        this._lev2Canvas.height = this.lev2Size.height;\r\n        this._lev3Canvas.width = this.lev3Size.width;\r\n        this._lev3Canvas.height = this.lev3Size.height;\r\n        this._helpCanvas.width = this.lev3Size.width / 2;\r\n        this._helpCanvas.height = this.lev3Size.height / 2;\r\n\r\n        this.container.appendChild(this._mainCanvas);\r\n\r\n        this._createImgsPath();\r\n        this._loadimg();\r\n        this.eventHandler();\r\n        this.startTimes();\r\n\r\n    }\r\n    drawLev1Img(index = 0) {\r\n        const img = this._lev1Imgs[index];\r\n       \r\n        this._lev1Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev1Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    drawLev2Img(index = 0) {\r\n        const img = this._lev2Imgs[index];\r\n       \r\n        this._lev2Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev2Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    drawLev3Img(index = 0) {\r\n        const img = this._lev3Imgs[index];\r\n       \r\n        this._lev3Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);\r\n        return {\r\n            canvas: this._lev3Canvas,\r\n            width: img.width,\r\n            height: img.height\r\n        }\r\n    }\r\n    mainDraw(canvas, sx, sy, sw, sh, x, y, w, h) {\r\n       \r\n        this._mainContext.clearRect(0, 0, this._width, this._height);\r\n\r\n            this._mainContext.drawImage(canvas, sx, sy, sw, sh, x, y, w, h);\r\n      \r\n    }\r\n\r\n    stopTimes() {\r\n        clearTimeout(this.stopTime);\r\n        this.startTimes();\r\n    }\r\n\r\n    startTimes() {\r\n        this.stopTime = setTimeout(() => {\r\n            parent.closeIFrame();\r\n        }, 18000);\r\n    }\r\n\r\n\r\n    eventHandler() {\r\n        let mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? \"DOMMouseScroll\" : \"mousewheel\";\r\n        const _this = this;\r\n        const dir = {\r\n            left: false,\r\n            right: false\r\n        }\r\n        const onmouseDown = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = true;\r\n\r\n            _this.recordX = _this.centerX;\r\n            _this.recordY = _this.centerY;\r\n\r\n            if (event.button == 0) {\r\n                _this.mouse._x = event.clientX;\r\n                _this.mouse._y = event.clientY;\r\n\r\n            }\r\n\r\n            _this._mainCanvas.addEventListener('mousemove', onmouseMove, false);\r\n            _this._mainCanvas.addEventListener('mouseup', onmouseUp, false);\r\n     \r\n\r\n        }\r\n        const onmouseMove = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.move = true;\r\n            _this.mouse.x = event.clientX;\r\n            _this.mouse.y = event.clientY;\r\n\r\n            _this.mouse.deltax = event.clientX - _this.mouse._x;\r\n            _this.mouse.deltay = event.clientY - _this.mouse._y;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.centerX = _this._width / 2;\r\n                _this.centerY = _this._height / 2;\r\n            } else {\r\n                _this.centerX = _this.recordX + _this.mouse.deltax;\r\n                _this.centerY = _this.recordY + _this.mouse.deltay;\r\n            }\r\n\r\n            if (!_this.autoplay) {\r\n                let deltax = event.movementX;\r\n\r\n                console.log(event.movementX);\r\n\r\n                dir.left = deltax > 0; //true 向右\r\n                dir.right = deltax < 0;\r\n\r\n                _this.turn(dir);\r\n            }\r\n          \r\n        }\r\n\r\n        const onmouseWheel = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            const wheelDir = (event.wheelDelta || -event.detail) > 0 ? 1 : 0; //0  down 小 1 up 大\r\n            _this.zoom(wheelDir, { x: event.clientX, y: event.clientY });\r\n\r\n        }\r\n        const onmouseUp = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = false;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.recordX = _this._width / 2;\r\n                _this.recordY = _this._height / 2;\r\n            } else {\r\n                _this.recordX = _this.centerX;\r\n                _this.recordY = _this.centerY;\r\n            }\r\n\r\n\r\n            dir.left = false;\r\n            dir.right = false;\r\n\r\n            _this._mainCanvas.removeEventListener('mousemove', onmouseMove, false);\r\n            _this._mainCanvas.removeEventListener('mouseup', onmouseUp, false);\r\n\r\n        }\r\n        const onWindowResize = function (event) {\r\n            window.location.reload();\r\n          \r\n\r\n        }\r\n\r\n        const onTouchstart = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = true;\r\n\r\n            _this.recordX = _this.centerX;\r\n            _this.recordY = _this.centerY;\r\n\r\n            if (event.touches.length == 1) {\r\n\r\n                _this.mouse._x = event.changedTouches[0].clientX;\r\n                _this.mouse._y = event.changedTouches[0].clientY;\r\n                _this.mouse.x = event.changedTouches[0].clientX;\r\n                _this.mouse.y = event.changedTouches[0].clientY;\r\n\r\n            } else if (event.touches.length == 2) {\r\n\r\n                let dx = event.touches[0].clientX - event.touches[1].clientX;\r\n                let dy = event.touches[0].clientY - event.touches[1].clientY;\r\n\r\n                let distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n                _this.dollyStart = distance;\r\n            }\r\n\r\n            _this._mainCanvas.addEventListener('touchmove', onTouchmove, false);\r\n            _this._mainCanvas.addEventListener('touchend', onTouchend, false);\r\n            _this.stopTimes();\r\n            // _this.render();\r\n        }\r\n\r\n        const onTouchmove = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.move = true;\r\n            if (event.touches.length == 1) {\r\n\r\n                _this.mouse.deltax = event.touches[0].clientX - _this.mouse._x;\r\n                _this.mouse.deltay = event.touches[0].clientY - _this.mouse._y;\r\n\r\n                if (_this.detai == 1) {\r\n                    _this.centerX = _this._width / 2;\r\n                    _this.centerY = _this._height / 2;\r\n                } else {\r\n                    _this.centerX = _this.recordX + event.touches[0].clientX - _this.mouse.x;\r\n                    _this.centerY = _this.recordY + event.touches[0].clientY - _this.mouse.y;\r\n                }\r\n\r\n                console.log(_this.centerX)\r\n\r\n                _this.mouse._x = event.changedTouches[0].clientX;\r\n                _this.mouse._y = event.changedTouches[0].clientY;\r\n\r\n                if (!_this.autoplay) {\r\n                  \r\n                    var deltax = _this.mouse.deltax;\r\n\r\n                    dir.left = deltax > 0; //true 向右\r\n                    dir.right = deltax < 0;\r\n\r\n                    _this.turn(dir);\r\n                    \r\n\r\n                }\r\n\r\n            } else {\r\n                var dx = event.touches[0].clientX - event.touches[1].clientX;\r\n                var dy = event.touches[0].clientY - event.touches[1].clientY;\r\n\r\n                var distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n                _this.dollyEnd = distance;\r\n\r\n                _this.dollyDelta = _this.dollyEnd - _this.dollyStart;\r\n\r\n                _this.dollyStart = _this.dollyEnd;\r\n\r\n\r\n                if (_this.dollyDelta > 0.5) {\r\n                   \r\n                    _this.zoom(1, { x: _this.centerX, y: _this.centerY } );\r\n \r\n                } else if(_this.dollyDelta < -0.5) {\r\n                \r\n                    _this.zoom(0, { x: _this.centerX, y: _this.centerY } );\r\n                  \r\n                }\r\n               \r\n            }\r\n            _this.stopTimes();\r\n            \r\n        }\r\n\r\n        const onTouchend = function (event) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n            _this.mouseState.down = false;\r\n            dir.left = false;\r\n            dir.right = false;\r\n\r\n            if (_this.detai == 1) {\r\n                _this.recordX = _this._width / 2;\r\n                _this.recordY = _this._height / 2;\r\n            } else {\r\n                _this.recordX = _this.centerX;\r\n                _this.recordY = _this.centerY;\r\n            }\r\n\r\n\r\n            _this._mainCanvas.removeEventListener('touchmove', onTouchmove, false);\r\n            _this._mainCanvas.removeEventListener('touchend', onTouchend, false);\r\n            _this.stopTimes();\r\n        }\r\n\r\n        if ('ontouchstart' in window) {\r\n            this._mainCanvas.addEventListener('touchstart', onTouchstart, false);\r\n           \r\n        } else {\r\n            this._mainCanvas.addEventListener('mousedown', onmouseDown, false);\r\n          \r\n        }\r\n\r\n        document.oncontextmenu = function () {\r\n            return false;\r\n        }\r\n\r\n        //兼容wheel事件\r\n        if (document.attachEvent) {\r\n            document.attachEvent('on' + mousewheelevt, ommouseWheel);\r\n        } else {\r\n            this._mainCanvas.addEventListener(mousewheelevt, onmouseWheel, {\r\n                passive: true\r\n            });\r\n\r\n        }\r\n\r\n        document.getElementsByClassName('playBtn')[0].addEventListener('click', () => {\r\n            if (!this.autoplay) {\r\n                document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn stop');\r\n                this.autoplay = true;\r\n            } else {\r\n                document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn play');\r\n                this.autoplay = false;\r\n            }\r\n\r\n            _this.stopTimes();\r\n        });\r\n        if ('ontouchstart' in window) {\r\n            \r\n        } else {\r\n            document.getElementsByClassName('right')[0].addEventListener('click', () => {\r\n                this.currentFrame--;\r\n            });\r\n            document.getElementsByClassName('left')[0].addEventListener('click', () => {\r\n                this.currentFrame++;\r\n            })\r\n        }\r\n\r\n        window.addEventListener('resize', onWindowResize, false);\r\n    }\r\n    render() {\r\n        this.timer++;\r\n        //重置当前Frame\r\n        this.currentFrame = this.currentFrame >= this.count ? 0 : (this.currentFrame < 0 ? this.count - 1 : this.currentFrame);\r\n        let param = this.drawLev1Img(this.currentFrame);\r\n        if (this.isloading2[this.currentFrame] == 'false') {\r\n            this.isloading2[this.currentFrame] = 'true';\r\n            this._loadLev2Img(this.currentFrame);\r\n        }\r\n\r\n        //按需加载\r\n        if (this.isloading[this.currentFrame] == 'false' && this.detai >= 8) {\r\n            this.isloading[this.currentFrame] = 'true';\r\n            !isWap && this._loadLev3Img(this.currentFrame);\r\n        }\r\n\r\n\r\n        if (this._lev2Imgs[this.currentFrame]) {\r\n            param = this.drawLev2Img(this.currentFrame);\r\n        }\r\n        if (this._lev3Imgs[this.currentFrame]) {\r\n            param = this.drawLev3Img(this.currentFrame);\r\n        }\r\n\r\n        //--开始剪切的起始位置 --被剪切图像的宽高 --在画布上放置的图像的起始位置 --使用的图像的宽高\r\n\r\n        this.mainDraw(param.canvas, 0, 0, param.width, param.height, this.centerX - this._endx / 2, this.centerY - this._endy / 2, this._endx, this._endy);\r\n       \r\n\r\n        requestAnimationFrame(() => {\r\n            this.render()\r\n        });\r\n\r\n\r\n        if (this.autoplay && this.handState.turn) {\r\n            this.centerX = this._width / 2;\r\n            this.centerY = this._height / 2;\r\n            this.detai = 1;\r\n            this.handState.zoom = false;\r\n            if (isWap) {\r\n                this._endx = this._width;\r\n                this._endy = this._width / this.proportion;\r\n            } else {\r\n                this._endx = this._height * this.proportion;\r\n                this._endy = this._height;    \r\n            }\r\n            if (this.timer % (30) === 0) this.currentFrame++;\r\n        } else {\r\n            this.handState.zoom = true;\r\n        }\r\n\r\n\r\n\r\n    }\r\n\r\n    //左右转向\r\n    turn(dir) {\r\n        if (!this.handState.turn) return;\r\n        if (dir.left && this.mouseState.down && this.detai < 2) {\r\n\r\n            this.currentFrame--;\r\n\r\n        }\r\n        if (dir.right && this.mouseState.down && this.detai < 2) {\r\n\r\n            this.currentFrame++;\r\n\r\n        }\r\n        // this.currentFrame >= this.count ? this.currentFrame = 0 : (this.currentFrame < 0 ? this.currentFrame = 44 : this.currentFrame);\r\n\r\n    }\r\n\r\n    //轮滑缩放\r\n    zoom(dir, pos) {\r\n        if (!this.handState.zoom) return;\r\n        if (dir > 0) {\r\n            this.detai += 1;\r\n            let maxdetai = 15;\r\n            this.detai <= maxdetai ? this.detai : this.detai = maxdetai;\r\n            if (this.detai < maxdetai) {\r\n                this._endx = this._endx * 1.1;\r\n                this._endy = this._endy * 1.1;\r\n            } else {\r\n                this._endx = this._endx;\r\n                this._endy = this._endy;\r\n            }\r\n            if (this.detai < 15) {\r\n                this.centerX = pos.x + (this.centerX - pos.x) * 1.1;\r\n                this.centerY = pos.y - (pos.y - this.centerY) * 1.1;\r\n            } else {\r\n                // this.centerX = pos.x + (this._width / 2 - pos.x) * Math.pow(1.1, 14);\r\n                // this.centerY = pos.y - (pos.y - this._height / 2) * Math.pow(1.1, 14);\r\n                this.centerX = this.centerX;\r\n                this.centerY = this.centerY;\r\n            }\r\n\r\n\r\n        } else {\r\n\r\n            this.detai += -1;\r\n\r\n            let mindetai = 1;\r\n            this.detai >= mindetai ? this.detai : this.detai = mindetai;\r\n\r\n\r\n            if (this.detai > mindetai) {\r\n                this._endx = this._endx / 1.1;\r\n                this._endy = this._endy / 1.1;\r\n            } else {\r\n                if (isWap) {\r\n                    this._endx = this._width;\r\n                    this._endy = this._width / this.proportion;\r\n                } else {\r\n                    this._endx = this._height * this.proportion;\r\n                    this._endy = this._height;    \r\n                }\r\n            }\r\n\r\n            if (this.detai == 1) {\r\n                this.centerX = this._width / 2;\r\n                this.centerY = this._height / 2;\r\n            } else {\r\n                this.centerX = pos.x + (this.centerX - pos.x) * 0.9;\r\n                this.centerY = pos.y - (pos.y - this.centerY) * 0.9;\r\n            }\r\n        }\r\n\r\n    }\r\n\r\n}\r\nexport default View360"]}"}