From 04cecbc16231c056ccbc843b9bfe3208458c7b37 Mon Sep 17 00:00:00 2001 From: pchen66 Date: Sun, 26 Apr 2020 23:21:39 -0700 Subject: [PATCH] Fix AzimuthAngleLimits Reset --- src/lib/controls/OrbitControls.js | 3 +++ src/panorama/PanoMomentPanorama.js | 16 ++++++++++++---- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/src/lib/controls/OrbitControls.js b/src/lib/controls/OrbitControls.js index 2b6589c3..4526edd4 100755 --- a/src/lib/controls/OrbitControls.js +++ b/src/lib/controls/OrbitControls.js @@ -129,6 +129,9 @@ function OrbitControls ( object, domElement ) { let state = STATE.NONE; + // eslint-disable-next-line no-unused-vars + let keyUp, keyBottom, keyLeft, keyRight; + // for reset this.target0 = this.target.clone(); diff --git a/src/panorama/PanoMomentPanorama.js b/src/panorama/PanoMomentPanorama.js index 27035223..489b71b4 100644 --- a/src/panorama/PanoMomentPanorama.js +++ b/src/panorama/PanoMomentPanorama.js @@ -67,6 +67,10 @@ PanoMomentPanorama.prototype = Object.assign( Object.create( Panorama.prototype * @param {THREE.Object[]} controls */ onPanolensControls: function( { controls } ) { + + const [ { minPolarAngle, maxPolarAngle } ] = controls; + + Object.assign( this.defaults, { minPolarAngle, maxPolarAngle } ); this.controls = controls; @@ -260,10 +264,14 @@ PanoMomentPanorama.prototype = Object.assign( Object.create( Panorama.prototype */ resetAzimuthAngleLimits: function( reset = false ) { - const { controls: [ OrbitControls ], - momentData: { contains_parallax, min_vertical_fov } , defaults, camera } = this; + const { + controls: [ OrbitControls ], + momentData: { contains_parallax, min_vertical_fov }, + defaults: { minPolarAngle, maxPolarAngle }, + camera + } = this; - if ( !contains_parallax ) return; + if ( !contains_parallax && !reset ) return; const delta = THREE.Math.degToRad( ( 0.95 * min_vertical_fov - camera.fov ) / 2 ); const angles = { @@ -271,7 +279,7 @@ PanoMomentPanorama.prototype = Object.assign( Object.create( Panorama.prototype maxPolarAngle: Math.PI / 2 + delta }; - Object.assign( OrbitControls, reset ? defaults : angles ); + Object.assign( OrbitControls, reset ? { minPolarAngle, maxPolarAngle } : angles ); },