main.js 165 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990
  1. // 图片加载进度
  2. let myJinDu = 0
  3. /* eslint-disable no-empty */
  4. /* eslint-disable no-unused-vars */
  5. /* eslint-disable no-console */
  6. /* eslint-disable no-undef */
  7. var isPhone = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
  8. navigator.userAgent
  9. );
  10. //设置字体大小
  11. calculateFontSize();
  12. //计算字体大小,返回数值大小
  13. function calculateFontSize() {
  14. var baseSize = isPhone ? 12 : 3
  15. , // 基数
  16. baseWidth = 375
  17. , //量取值大小
  18. winw = document.documentElement.clientWidth
  19. , fontSize = ((winw / baseWidth) * baseSize).toFixed(2);
  20. document.getElementsByTagName('html')[0].style.fontSize = fontSize + 'px';
  21. return fontSize;
  22. }
  23. $(window).resize(function () {
  24. calculateFontSize();
  25. });
  26. (function () {
  27. function r(e, n, t) {
  28. function o(i, f) {
  29. if (!n[i]) {
  30. if (!e[i]) {
  31. var c = 'function' == typeof require && require;
  32. if (!f && c)
  33. return c(i, !0);
  34. if (u)
  35. return u(i, !0);
  36. var a = new Error("Cannot find module '" + i + "'");
  37. throw ((a.code = 'MODULE_NOT_FOUND'),
  38. a);
  39. }
  40. var p = (n[i] = {
  41. exports: {}
  42. });
  43. e[i][0].call(p.exports, function (r) {
  44. var n = e[i][1][r];
  45. return o(n || r);
  46. }, p, p.exports, r, e, n, t);
  47. }
  48. return n[i].exports;
  49. }
  50. for (var u = 'function' == typeof require && require, i = 0; i < t.length; i++)
  51. o(t[i]);
  52. return o;
  53. }
  54. return r;
  55. }
  56. )()({
  57. 1: [function (require, module, exports) {
  58. 'use strict';
  59. var _View = require('./view360');
  60. var _View2 = _interopRequireDefault(_View);
  61. function _interopRequireDefault(obj) {
  62. return obj && obj.__esModule ? obj : {
  63. default: obj
  64. };
  65. }
  66. //maybe
  67. var imgsize = new Image();
  68. // 邵根
  69. imgsize.src = imgURL + '/0001.' + m_info.houzui;
  70. // 修改 图片 宽高
  71. // const myWidth = window.innerWidth
  72. // const myHeight = window.innerHeight
  73. // imgsize.onload = function () {
  74. // console.log('---------',imgsize.width,imgsize.height);
  75. // console.log('---------222',myWidth,myHeight);
  76. // var config1 = {
  77. // container: document.getElementById('container'),
  78. // imgsURL: imgURL,
  79. // count: imgCounts,
  80. // lev1Size: {
  81. // width: myWidth,
  82. // height: myHeight,
  83. // },
  84. // lev2Size: {
  85. // width: myWidth * 2,
  86. // height: myHeight * 2,
  87. // },
  88. // lev3Size: {
  89. // width: myWidth * 6,
  90. // height: myHeight * 6,
  91. // },
  92. // horizontal: myWidth < myHeight ? 8 : 12,
  93. // vertical: myWidth < myHeight ? 12 : 8,
  94. // };
  95. // var viewer = new _View2.default(config1);
  96. // viewer.init();
  97. // }
  98. imgsize.onload = function () {
  99. var config1 = {
  100. container: document.getElementById('container'),
  101. imgsURL: imgURL,
  102. count: imgCounts,
  103. lev1Size: {
  104. width: imgsize.width,
  105. height: imgsize.height,
  106. },
  107. lev2Size: {
  108. width: imgsize.width * 2,
  109. height: imgsize.height * 2,
  110. },
  111. lev3Size: {
  112. width: imgsize.width * 6,
  113. height: imgsize.height * 6,
  114. },
  115. horizontal: imgsize.width < imgsize.height ? 8 : 12,
  116. vertical: imgsize.width < imgsize.height ? 12 : 8,
  117. };
  118. var viewer = new _View2.default(config1);
  119. viewer.init();
  120. }
  121. ;
  122. }
  123. , {
  124. './view360': 2
  125. },],
  126. 2: [function (require, module, exports) {
  127. 'use strict';
  128. Object.defineProperty(exports, '__esModule', {
  129. value: true,
  130. });
  131. var _createClass = (function () {
  132. function defineProperties(target, props) {
  133. for (var i = 0; i < props.length; i++) {
  134. var descriptor = props[i];
  135. descriptor.enumerable = descriptor.enumerable || false;
  136. descriptor.configurable = true;
  137. if ('value' in descriptor)
  138. descriptor.writable = true;
  139. Object.defineProperty(target, descriptor.key, descriptor);
  140. }
  141. }
  142. return function (Constructor, protoProps, staticProps) {
  143. if (protoProps)
  144. defineProperties(Constructor.prototype, protoProps);
  145. if (staticProps)
  146. defineProperties(Constructor, staticProps);
  147. return Constructor;
  148. }
  149. ;
  150. }
  151. )();
  152. function _classCallCheck(instance, Constructor) {
  153. if (!(instance instanceof Constructor)) {
  154. throw new TypeError('Cannot call a class as a function');
  155. }
  156. }
  157. var isWap = /Android|webOS| iPhone | iPad | iPod |BlackBerry|opera mini|opera mobile|appleWebkit.*mobile|mobile/i.test(navigator.userAgent);
  158. var View360 = (function () {
  159. function View360(config) {
  160. _classCallCheck(this, View360);
  161. this.container = config.container;
  162. this.imgsURL = config.imgsURL;
  163. this.count = config.count;
  164. this.currentFrame = 0;
  165. this.lev1Size = config.lev1Size;
  166. this.lev2Size = config.lev2Size;
  167. this.lev3Size = config.lev3Size;
  168. this._height = this.container.clientHeight;
  169. this._width = this.container.clientWidth;
  170. //宽高比比率
  171. this.proportion = this.lev1Size.width / this.lev1Size.height;
  172. this._mainCanvas = document.createElement('canvas');
  173. this._mainContext = this._mainCanvas.getContext('2d');
  174. this._lev1Canvas = document.createElement('canvas');
  175. this._lev1Context = this._lev1Canvas.getContext('2d');
  176. this._lev2Canvas = document.createElement('canvas');
  177. this._lev2Context = this._lev2Canvas.getContext('2d');
  178. this._lev3Canvas = document.createElement('canvas');
  179. this._lev3Context = this._lev3Canvas.getContext('2d');
  180. this._helpCanvas = document.createElement('canvas');
  181. this._helpContext = this._helpCanvas.getContext('2d');
  182. this._lev1ImgsPath = [];
  183. this._lev2ImgsPath = [];
  184. this._lev3ImgsPath = [];
  185. this._lev1Imgs = [];
  186. this._lev2Imgs = [];
  187. this._lev3Imgs = [];
  188. //初始缩放级别
  189. this.detai = 1;
  190. //缩放坐标值
  191. this.dollyStart = 0;
  192. this.dollyEnd = 0;
  193. this.dollyDelta = 0;
  194. //画布初始着色点
  195. this._starty = 0;
  196. if (isWap) {
  197. this._endx = this._width;
  198. this._endy = this._width / this.proportion;
  199. } else {
  200. this._endx = this._height * this.proportion;
  201. this._endy = this._height;
  202. }
  203. this.centerX = this._width / 2;
  204. this.centerY = this._height / 2;
  205. this.recordX = 0;
  206. this.recordY = 0;
  207. this.mouse = {
  208. x: 0,
  209. y: 0,
  210. _x: 0,
  211. _y: 0,
  212. deltax: 0,
  213. deltay: 0,
  214. };
  215. this.mouseState = {
  216. down: false,
  217. move: false,
  218. };
  219. this.handState = {
  220. zoom: true,
  221. turn: true,
  222. move: false,
  223. };
  224. this.timer = 0;
  225. //加载级别数组判定
  226. this.isloading2 = [];
  227. this.isloading = [];
  228. this.isloading.length = this.count;
  229. for (var i = 0; i < this.count; i++) {
  230. this.isloading[i] = 'false';
  231. this.isloading2[i] = 'false';
  232. }
  233. this.horizontal = config.horizontal;
  234. this.vertical = config.vertical;
  235. //console.log(this.isloading);
  236. //设置播放状态
  237. this.autoplay = false;
  238. this.stopTime = 0;
  239. }
  240. //获取图片路径,基本不用改
  241. // 邵根----修改图片 名字和顺序
  242. _createClass(View360, [{
  243. key: '_createImgsPath',
  244. value: function _createImgsPath() {
  245. for (var i = 0; i < this.count; i++) {
  246. let myName = '/000' + (i + 1)
  247. myName = myName.substr(-4)
  248. var src = `${this.imgsURL}/${myName}.${m_info.houzui}`;
  249. this._lev1ImgsPath.push(src);
  250. }
  251. // 邵根
  252. // for (var _i = 0; _i < this.count; _i++) {
  253. // var _src = this.imgsURL + '/2/2_' + _i + '.jpg';
  254. // this._lev2ImgsPath.push(_src);
  255. // console.log('------222');
  256. // }
  257. // for (var _i2 = 0; _i2 < this.count; _i2++) {
  258. // var tmp = [];
  259. // var base = this.imgsURL + '/3/' + _i2 + '/3_' + _i2;
  260. // for (var j = 0; j < 96; j++) {
  261. // var url = base + '_' + j + '.jpg';
  262. // tmp.push(url);
  263. // }
  264. // this._lev3ImgsPath.push(tmp);
  265. // console.log('------333');
  266. // }
  267. //console.log(this._lev3ImgsPath);
  268. },
  269. //加载一级图片
  270. }, {
  271. key: '_loadimg',
  272. value: function _loadimg() {
  273. var _this2 = this;
  274. var lev1Promise = this._lev1ImgsPath.map(function (item) {
  275. return new Promise(function (resolve, reject) {
  276. var img = new Image();
  277. img.src = item;
  278. img.onload = function () {
  279. myJinDu += 1
  280. // console.log('----',myJinDu);
  281. // 总数
  282. const baiFenBi = (myJinDu / imgCounts) * 100 + '%'
  283. document.querySelector('.lodingJindu').style.width = baiFenBi
  284. return resolve(img);
  285. }
  286. ;
  287. img.onerror = function (err) {
  288. return reject(err);
  289. }
  290. ;
  291. }
  292. );
  293. });
  294. Promise.all(lev1Promise).then(function (imgs) {
  295. _this2._lev1Imgs = imgs;
  296. // 邵根
  297. console.log('加载完成!!!!');
  298. const titDom = document.createElement('img')
  299. titDom.setAttribute('id', 'hand')
  300. titDom.setAttribute('class', 'hand')
  301. // oss路径问题
  302. titDom.setAttribute('src', `${envUrl}img/hand.png`)
  303. document.querySelector('body').appendChild(titDom)
  304. $('.loding').css({ 'opacity': '0', 'pointer-events': 'none' })
  305. // setTimeout(function () {
  306. // document.getElementById("hand").style.display = "none";
  307. // }, 2000);
  308. _this2.render();
  309. }).catch(function (err) {
  310. return console.log(err);
  311. });
  312. },
  313. },
  314. {
  315. key: '_loadLev2Img',
  316. value: function _loadLev2Img() {
  317. var _this3 = this;
  318. var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
  319. //console.log('come loading2');
  320. var lev2Promise = new Promise(function (resolve, reject) {
  321. var img = new Image();
  322. // 邵根
  323. if (!_this3._lev2ImgsPath[index]) return
  324. img.src = _this3._lev2ImgsPath[index];
  325. img.onload = function () {
  326. return resolve(img);
  327. }
  328. ;
  329. img.onerror = function (err) {
  330. return reject(err);
  331. }
  332. ;
  333. }
  334. );
  335. lev2Promise.then(function (imgs) {
  336. _this3._lev2Imgs[index] = imgs;
  337. }).catch(function (err) {
  338. return console.log(err);
  339. });
  340. },
  341. },
  342. {
  343. key: '_loadLev3Img',
  344. value: function _loadLev3Img() {
  345. var _this4 = this;
  346. var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
  347. var lev3Promise = this._lev3ImgsPath[index].map(function (item) {
  348. return new Promise(function (resolve, reject) {
  349. var img = new Image();
  350. img.src = item;
  351. img.onload = function () {
  352. return resolve(img);
  353. }
  354. ;
  355. img.onerror = function (err) {
  356. return reject(err);
  357. }
  358. ;
  359. }
  360. );
  361. });
  362. Promise.all(lev3Promise).then(function (imgs) {
  363. var offsetW = 0;
  364. var offsetWs = [];
  365. var offsetH = 0;
  366. var offsetHs = [];
  367. var counts = 0;
  368. for (var i = 1; i <= _this4.vertical; i++) {
  369. offsetH += imgs[i * _this4.horizontal - 1].height;
  370. offsetW = 0;
  371. for (var j = 1; j <= _this4.horizontal; j++) {
  372. counts++;
  373. offsetW += imgs[1 * j - 1].width;
  374. //console.log(this._helpCanvas.width, this._helpCanvas.height);
  375. offsetHs.push(offsetH - imgs[i * _this4.horizontal - 1].height);
  376. offsetWs.push(offsetW - imgs[1 * j - 1].width);
  377. var m = counts - 1;
  378. _this4._helpContext.drawImage(imgs[m], offsetWs[m] / 2, offsetHs[m] / 2, imgs[m].width / 2, imgs[m].height / 2);
  379. }
  380. }
  381. var _img = new Image();
  382. _img.src = _this4._helpCanvas.toDataURL();
  383. _img.onload = function () {
  384. _this4._lev3Imgs[index] = _img;
  385. }
  386. ;
  387. });
  388. },
  389. },
  390. {
  391. key: 'init',
  392. value: function init() {
  393. //创建相应的功能按钮,左右切换
  394. var btn = document.createElement('div');
  395. btn.setAttribute('class', 'btn');
  396. if ('ontouchstart' in window) {// let fanhui = document.createElement('div');
  397. // fanhui.setAttribute('class', 'fanhui dir');
  398. // btn.appendChild(fanhui);
  399. } else {
  400. var left = document.createElement('div');
  401. var right = document.createElement('div');
  402. left.setAttribute('class', 'left dir');
  403. right.setAttribute('class', 'right dir');
  404. btn.appendChild(left);
  405. btn.appendChild(right);
  406. }
  407. document.body.appendChild(btn);
  408. //创建播放按钮
  409. var playBtn = document.createElement('div');
  410. playBtn.setAttribute('class', 'playBtn play');
  411. btn.appendChild(playBtn);
  412. if (isPhone) {
  413. // $('.btn').hide();
  414. document.getElementsByClassName('btn')[0].style.display = 'none';
  415. }
  416. this._mainCanvas.width = this._width;
  417. this._mainCanvas.height = this._height;
  418. this._lev1Canvas.width = this.lev1Size.width;
  419. this._lev1Canvas.height = this.lev1Size.height;
  420. this._lev2Canvas.width = this.lev2Size.width;
  421. this._lev2Canvas.height = this.lev2Size.height;
  422. this._lev3Canvas.width = this.lev3Size.width;
  423. this._lev3Canvas.height = this.lev3Size.height;
  424. this._helpCanvas.width = this.lev3Size.width / 2;
  425. this._helpCanvas.height = this.lev3Size.height / 2;
  426. this.container.appendChild(this._mainCanvas);
  427. this._createImgsPath();
  428. this._loadimg();
  429. this.eventHandler();
  430. this.startTimes();
  431. },
  432. }, {
  433. key: 'drawLev1Img',
  434. value: function drawLev1Img() {
  435. var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
  436. var img = this._lev1Imgs[index];
  437. this._lev1Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);
  438. return {
  439. canvas: this._lev1Canvas,
  440. width: img.width,
  441. height: img.height,
  442. };
  443. },
  444. }, {
  445. key: 'drawLev2Img',
  446. value: function drawLev2Img() {
  447. var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
  448. var img = this._lev2Imgs[index];
  449. this._lev2Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);
  450. return {
  451. canvas: this._lev2Canvas,
  452. width: img.width,
  453. height: img.height,
  454. };
  455. },
  456. }, {
  457. key: 'drawLev3Img',
  458. value: function drawLev3Img() {
  459. var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
  460. var img = this._lev3Imgs[index];
  461. this._lev3Context.drawImage(img, 0, 0, img.width, img.height, 0, 0, img.width, img.height);
  462. return {
  463. canvas: this._lev3Canvas,
  464. width: img.width,
  465. height: img.height,
  466. };
  467. },
  468. }, {
  469. key: 'mainDraw',
  470. value: function mainDraw(canvas, sx, sy, sw, sh, x, y, w, h) {
  471. this._mainContext.clearRect(0, 0, this._width, this._height);
  472. this._mainContext.drawImage(canvas, sx, sy, sw, sh, x, y, w, h);
  473. },
  474. }, {
  475. key: 'stopTimes',
  476. value: function stopTimes() {
  477. clearTimeout(this.stopTime);
  478. this.startTimes();
  479. },
  480. }, {
  481. key: 'startTimes',
  482. value: function startTimes() {
  483. this.stopTime = setTimeout(function () {
  484. parent.closeIFrame();
  485. }, 18000);
  486. },
  487. }, {
  488. key: 'eventHandler',
  489. value: function eventHandler() {
  490. var _this5 = this;
  491. var mousewheelevt = /Firefox/i.test(navigator.userAgent) ? 'DOMMouseScroll' : 'mousewheel';
  492. var _this = this;
  493. var dir = {
  494. left: false,
  495. right: false,
  496. };
  497. var onmouseDown = function onmouseDown(event) {
  498. event.preventDefault();
  499. event.stopPropagation();
  500. _this.mouseState.down = true;
  501. _this.recordX = _this.centerX;
  502. _this.recordY = _this.centerY;
  503. if (event.button == 0) {
  504. _this.mouse._x = event.clientX;
  505. _this.mouse._y = event.clientY;
  506. }
  507. _this._mainCanvas.addEventListener('mousemove', onmouseMove, false);
  508. _this._mainCanvas.addEventListener('mouseup', onmouseUp, false);
  509. };
  510. var onmouseMove = function onmouseMove(event) {
  511. event.preventDefault();
  512. event.stopPropagation();
  513. _this.mouseState.move = true;
  514. _this.mouse.x = event.clientX;
  515. _this.mouse.y = event.clientY;
  516. _this.mouse.deltax = event.clientX - _this.mouse._x;
  517. _this.mouse.deltay = event.clientY - _this.mouse._y;
  518. if (_this.detai == 1) {
  519. _this.centerX = _this._width / 2;
  520. _this.centerY = _this._height / 2;
  521. } else {
  522. _this.centerX = _this.recordX + _this.mouse.deltax;
  523. _this.centerY = _this.recordY + _this.mouse.deltay;
  524. }
  525. if (!_this.autoplay) {
  526. var deltax = event.movementX;
  527. dir.left = deltax > 0;
  528. //true 向右
  529. dir.right = deltax < 0;
  530. _this.turn(dir);
  531. }
  532. };
  533. var onmouseWheel = function onmouseWheel(event) {
  534. event.preventDefault();
  535. event.stopPropagation();
  536. var wheelDir = (event.wheelDelta || -event.detail) > 0 ? 1 : 0;
  537. //0 down 小 1 up 大
  538. _this.zoom(wheelDir, {
  539. x: event.clientX,
  540. y: event.clientY
  541. });
  542. };
  543. var onmouseUp = function onmouseUp(event) {
  544. event.preventDefault();
  545. event.stopPropagation();
  546. _this.mouseState.down = false;
  547. if (_this.detai == 1) {
  548. _this.recordX = _this._width / 2;
  549. _this.recordY = _this._height / 2;
  550. } else {
  551. _this.recordX = _this.centerX;
  552. _this.recordY = _this.centerY;
  553. }
  554. dir.left = false;
  555. dir.right = false;
  556. _this._mainCanvas.removeEventListener('mousemove', onmouseMove, false);
  557. _this._mainCanvas.removeEventListener('mouseup', onmouseUp, false);
  558. };
  559. var onWindowResize = function onWindowResize(event) {
  560. window.location.reload();
  561. };
  562. var onTouchstart = function onTouchstart(event) {
  563. event.preventDefault();
  564. event.stopPropagation();
  565. _this.mouseState.down = true;
  566. _this.recordX = _this.centerX;
  567. _this.recordY = _this.centerY;
  568. if (event.touches.length == 1) {
  569. _this.mouse._x = event.changedTouches[0].clientX;
  570. _this.mouse._y = event.changedTouches[0].clientY;
  571. _this.mouse.x = event.changedTouches[0].clientX;
  572. _this.mouse.y = event.changedTouches[0].clientY;
  573. } else if (event.touches.length == 2) {
  574. var dx = event.touches[0].clientX - event.touches[1].clientX;
  575. var dy = event.touches[0].clientY - event.touches[1].clientY;
  576. var distance = Math.sqrt(dx * dx + dy * dy);
  577. _this.dollyStart = distance;
  578. }
  579. _this._mainCanvas.addEventListener('touchmove', onTouchmove, false);
  580. _this._mainCanvas.addEventListener('touchend', onTouchend, false);
  581. _this.stopTimes();
  582. // _this.render();
  583. };
  584. var onTouchmove = function onTouchmove(event) {
  585. event.preventDefault();
  586. event.stopPropagation();
  587. _this.mouseState.move = true;
  588. if (event.touches.length == 1) {
  589. _this.mouse.deltax = event.touches[0].clientX - _this.mouse._x;
  590. _this.mouse.deltay = event.touches[0].clientY - _this.mouse._y;
  591. if (_this.detai == 1) {
  592. _this.centerX = _this._width / 2;
  593. _this.centerY = _this._height / 2;
  594. } else {
  595. _this.centerX = _this.recordX + event.touches[0].clientX - _this.mouse.x;
  596. _this.centerY = _this.recordY + event.touches[0].clientY - _this.mouse.y;
  597. }
  598. // console.log(_this.centerX);
  599. _this.mouse._x = event.changedTouches[0].clientX;
  600. _this.mouse._y = event.changedTouches[0].clientY;
  601. if (!_this.autoplay) {
  602. var deltax = _this.mouse.deltax;
  603. dir.left = deltax > 0;
  604. //true 向右
  605. dir.right = deltax < 0;
  606. _this.turn(dir);
  607. }
  608. } else {
  609. var dx = event.touches[0].clientX - event.touches[1].clientX;
  610. var dy = event.touches[0].clientY - event.touches[1].clientY;
  611. var distance = Math.sqrt(dx * dx + dy * dy);
  612. _this.dollyEnd = distance;
  613. _this.dollyDelta = _this.dollyEnd - _this.dollyStart;
  614. _this.dollyStart = _this.dollyEnd;
  615. if (_this.dollyDelta > 0.5) {
  616. _this.zoom(1, {
  617. x: _this.centerX,
  618. y: _this.centerY
  619. });
  620. } else if (_this.dollyDelta < -0.5) {
  621. _this.zoom(0, {
  622. x: _this.centerX,
  623. y: _this.centerY
  624. });
  625. }
  626. }
  627. _this.stopTimes();
  628. };
  629. var onTouchend = function onTouchend(event) {
  630. event.preventDefault();
  631. event.stopPropagation();
  632. _this.mouseState.down = false;
  633. dir.left = false;
  634. dir.right = false;
  635. if (_this.detai == 1) {
  636. _this.recordX = _this._width / 2;
  637. _this.recordY = _this._height / 2;
  638. } else {
  639. _this.recordX = _this.centerX;
  640. _this.recordY = _this.centerY;
  641. }
  642. _this._mainCanvas.removeEventListener('touchmove', onTouchmove, false);
  643. _this._mainCanvas.removeEventListener('touchend', onTouchend, false);
  644. _this.stopTimes();
  645. };
  646. if ('ontouchstart' in window) {
  647. this._mainCanvas.addEventListener('touchstart', onTouchstart, false);
  648. } else {
  649. this._mainCanvas.addEventListener('mousedown', onmouseDown, false);
  650. }
  651. document.oncontextmenu = function () {
  652. return false;
  653. }
  654. ;
  655. //兼容wheel事件
  656. if (document.attachEvent) {
  657. document.attachEvent('on' + mousewheelevt, ommouseWheel);
  658. } else {
  659. this._mainCanvas.addEventListener(mousewheelevt, onmouseWheel, {
  660. passive: true,
  661. });
  662. }
  663. // 邵根
  664. // document.getElementsByClassName('playBtn')[0].addEventListener('click', function () {
  665. // if (!_this5.autoplay) {
  666. // document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn stop');
  667. // _this5.autoplay = true;
  668. // } else {
  669. // document.getElementsByClassName('playBtn')[0].setAttribute('class', 'playBtn play');
  670. // _this5.autoplay = false;
  671. // }
  672. // _this.stopTimes();
  673. // });
  674. // document.getElementsByClassName('pplayBtn')[0].addEventListener('click', function () {
  675. // if (!_this5.autoplay) {
  676. // document.getElementsByClassName('pplayBtn')[0].setAttribute('class', 'pplayBtn stop');
  677. // _this5.autoplay = true;
  678. // } else {
  679. // document.getElementsByClassName('pplayBtn')[0].setAttribute('class', 'pplayBtn play');
  680. // _this5.autoplay = false;
  681. // }
  682. // _this.stopTimes();
  683. // });
  684. // if ('ontouchstart' in window) { } else {
  685. // document.getElementsByClassName('right')[0].addEventListener('click', function () {
  686. // _this5.currentFrame--;
  687. // });
  688. // document.getElementsByClassName('left')[0].addEventListener('click', function () {
  689. // _this5.currentFrame++;
  690. // });
  691. // }
  692. window.addEventListener('resize', onWindowResize, false);
  693. },
  694. }, {
  695. key: 'render',
  696. value: function render() {
  697. // 邵根 -- 当前滑动的图片是第几张
  698. // console.log('----当前滑动的图片---', this.currentFrame, this.count);
  699. var _this6 = this;
  700. this.timer++;
  701. //重置当前Frame
  702. this.currentFrame = this.currentFrame >= this.count ? 0 : this.currentFrame < 0 ? this.count - 1 : this.currentFrame;
  703. var param = this.drawLev1Img(this.currentFrame);
  704. if (this.isloading2[this.currentFrame] == 'false') {
  705. this.isloading2[this.currentFrame] = 'true';
  706. this._loadLev2Img(this.currentFrame);
  707. }
  708. //按需加载
  709. if (this.isloading[this.currentFrame] == 'false' && this.detai >= 8) {
  710. this.isloading[this.currentFrame] = 'true';
  711. }
  712. if (this._lev2Imgs[this.currentFrame]) {
  713. param = this.drawLev2Img(this.currentFrame);
  714. }
  715. if (this._lev3Imgs[this.currentFrame]) {
  716. param = this.drawLev3Img(this.currentFrame);
  717. }
  718. //--开始剪切的起始位置 --被剪切图像的宽高 --在画布上放置的图像的起始位置 --使用的图像的宽高
  719. this.mainDraw(param.canvas, 0, 0, param.width, param.height, this.centerX - this._endx / 2, this.centerY - this._endy / 2, this._endx, this._endy);
  720. requestAnimationFrame(function () {
  721. _this6.render();
  722. });
  723. if (this.autoplay && this.handState.turn) {
  724. this.centerX = this._width / 2;
  725. this.centerY = this._height / 2;
  726. this.detai = 1;
  727. this.handState.zoom = false;
  728. if (isWap) {
  729. this._endx = this._width;
  730. this._endy = this._width / this.proportion;
  731. } else {
  732. this._endx = this._height * this.proportion;
  733. this._endy = this._height;
  734. }
  735. if (this.timer % 30 === 0)
  736. this.currentFrame++;
  737. } else {
  738. this.handState.zoom = true;
  739. }
  740. },
  741. //左右转向
  742. }, {
  743. key: 'turn',
  744. value: function turn(dir) {
  745. if (!this.handState.turn)
  746. return;
  747. if (dir.left && this.mouseState.down && this.detai < 2) {
  748. // console.log('左滑倒退', this.currentFrame);
  749. if (this.currentFrame <= 0) this.currentFrame = 0
  750. else this.currentFrame--;
  751. }
  752. if (dir.right && this.mouseState.down && this.detai < 2) {
  753. // console.log('右滑前进', this.currentFrame);
  754. if (this.currentFrame >= imgCounts - 1) this.currentFrame = imgCounts - 1
  755. else this.currentFrame++;
  756. }
  757. // this.currentFrame >= this.count ? this.currentFrame = 0 : (this.currentFrame < 0 ? this.currentFrame = imgCounts : this.currentFrame);
  758. // 邵根 -滚动条
  759. const nowImgNum = this.currentFrame + 1
  760. console.log('-当前滚动到的图片:', nowImgNum);
  761. let nowGunBai = (nowImgNum / imgCounts) * 100
  762. document.querySelector('.gunDongDomSon').style.top = nowGunBai + '%'
  763. },
  764. //轮滑缩放
  765. }, {
  766. key: 'zoom',
  767. value: function zoom(dir, pos) {
  768. if (!this.handState.zoom)
  769. return;
  770. if (dir > 0) {
  771. this.detai += 1;
  772. var maxdetai = 15;
  773. this.detai <= maxdetai ? this.detai : (this.detai = maxdetai);
  774. if (this.detai < maxdetai) {
  775. this._endx = this._endx * 1.1;
  776. this._endy = this._endy * 1.1;
  777. } else {
  778. this._endx = this._endx;
  779. this._endy = this._endy;
  780. }
  781. if (this.detai < 15) {
  782. this.centerX = pos.x + (this.centerX - pos.x) * 1.1;
  783. this.centerY = pos.y - (pos.y - this.centerY) * 1.1;
  784. } else {
  785. // this.centerX = pos.x + (this._width / 2 - pos.x) * Math.pow(1.1, 14);
  786. // this.centerY = pos.y - (pos.y - this._height / 2) * Math.pow(1.1, 14);
  787. this.centerX = this.centerX;
  788. this.centerY = this.centerY;
  789. }
  790. } else {
  791. this.detai += -1;
  792. var mindetai = 1;
  793. this.detai >= mindetai ? this.detai : (this.detai = mindetai);
  794. if (this.detai > mindetai) {
  795. this._endx = this._endx / 1.1;
  796. this._endy = this._endy / 1.1;
  797. } else {
  798. if (isWap) {
  799. this._endx = this._width;
  800. this._endy = this._width / this.proportion;
  801. } else {
  802. this._endx = this._height * this.proportion;
  803. this._endy = this._height;
  804. }
  805. }
  806. if (this.detai == 1) {
  807. this.centerX = this._width / 2;
  808. this.centerY = this._height / 2;
  809. } else {
  810. this.centerX = pos.x + (this.centerX - pos.x) * 0.9;
  811. this.centerY = pos.y - (pos.y - this.centerY) * 0.9;
  812. }
  813. }
  814. },
  815. },]);
  816. return View360;
  817. }
  818. )();
  819. exports.default = View360;
  820. }
  821. , {},],
  822. }, {}, [1]);
  823. //# 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"]}"}