You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
cameraControls.smoothTime defaults to 0.25. You can set it to higher values for slower transitions of dollyInFixed in infinite dolly mode. But if, at any time, you use a pinch motion on mobile to move forwards or backwards, and then call dollyInFixed, the transition will execute with a smoothTime of 0.25, even if you try to set it again to a higher value.
This is happening on Android on a Samsung Galaxy A21 in both Firefox and the Samsung 'Internet' browser.
It doesn't happen on desktop.
To Reproduce
Steps to reproduce the behavior:
Modify the infinite dolly example so that cameraControls.smoothTime = 1.0; is always set before the call to dollyInFixed.
Load the example on mobile. (happened for me on mobile: firefox, android, samsung galaxy a21)
Click on dollyInFixed 1 or -1. The transitions are slow as expected.
Use a pinch motion to move forwards/backwards.
Click on dollyInFixed 1 or -1 again. The transitions are fast, as if smoothTime has not been set.
The code is below. It's just the infinite dolly example with two lines changed.
Code
<!DOCTYPEhtml><html><head><metacharset="utf-8"><metaname="viewport"content="width=device-width"><title>=^.^=</title><linkrel="stylesheet"href="./style.css"></head><body><divclass="info"><p><ahref="https://github.com/yomotsu/camera-controls">GitHub repo</a></p><p>If you enable infinityDolly, you must set min and max distance as well.</p><label><inputtype="checkbox"onchange="cameraControls.dollyToCursor = this.checked"checked>dolly to cursor</label><br><label><inputtype="checkbox"onchange="cameraControls.infinityDolly = this.checked"checked>infinity dolly</label><br><label><inputtype="radio"name="range"onchange="setRange( 0 )">distance: min: 5, max: 5</label><br><label><inputtype="radio"name="range"onchange="setRange( 1 )"checked>distance: min: 3, max: 7</label><br><label><inputtype="radio"name="range"onchange="setRange( 2 )">distance: min: 1, max: 10</label><br><buttononclick="cameraControls.dolly( 1, true )">dolly 1</button><buttononclick="cameraControls.dolly( - 1, true )">dolly -1</button><br><buttononclick="cameraControls.smoothTime = 1.0; cameraControls.dollyInFixed( 1, true )">dollyInFixed 1</button><buttononclick="cameraControls.smoothTime = 1.0; cameraControls.dollyInFixed( - 1, true )">dollyInFixed -1</button><br><buttononclick="cameraControls.reset( true )">reset</button></div><scriptasyncsrc="https://unpkg.com/es-module-shims@1.8.2/dist/es-module-shims.js"></script><scripttype="importmap">{"imports": {"three": "https://unpkg.com/three@0.161.0/build/three.module.js","three/addons/": "https://unpkg.com/three@0.161.0/examples/jsm/"}}</script><scripttype="module">
import * as THREE from 'three';
import CameraControls from 'camera-controls';
CameraControls.install( {THREE: THREE} );
const width = window.innerWidth;
const height = window.innerHeight;
const clock = new THREE.Clock();
const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera( 60, width / height, 0.01, 100 );
camera.position.set( 0, 0, 5 );
const renderer = new THREE.WebGLRenderer();
renderer.setSize( width, height );
document.body.appendChild( renderer.domElement );
const cameraControls = new CameraControls( camera, renderer.domElement );
cameraControls.infinityDolly = true;
cameraControls.dollyToCursor = true;
console.log(cameraControls.smoothTime);
//cameraControls.smoothTime = 1.0;
setRange( 1 );
const mesh = new THREE.Mesh(
new THREE.BoxGeometry( 1, 1, 1 ),
new THREE.MeshBasicMaterial( {color: 0xff0000,wireframe: true} )
);
scene.add( mesh );
const centerHelper = new THREE.Mesh(
new THREE.SphereGeometry( .05 ),
new THREE.MeshBasicMaterial( {color: 0xffff00} )
)
scene.add( centerHelper );
const gridHelper = new THREE.GridHelper( 50, 50 );
gridHelper.position.y = - 1;
scene.add( gridHelper );
renderer.render( scene, camera );
( function anim () {constdelta=clock.getDelta();constelapsed=clock.getElapsedTime();constupdated=cameraControls.update(delta);// if ( elapsed > 30 ) { return; }requestAnimationFrame(anim);if(updated){cameraControls.getTarget(centerHelper.position,false);renderer.render(scene,camera);console.log('rendered');}})();document.querySelectorAll( '.infoinput' )[1].addEventListener( 'change',(event)=>{constenabled=event.target.checked;document.querySelectorAll('.info input[name="range"]').forEach((inputEl)=>{inputEl.checked=false;inputEl.disabled=!enabled;cameraControls.minDistance=0;cameraControls.maxDistance=Infinity;});} );
function setRange ( type ) {cameraControls.dollyTo(5,true);if(type===0){cameraControls.minDistance=5;cameraControls.maxDistance=5;} else if ( type === 1 ) {cameraControls.minDistance=3;cameraControls.maxDistance=7;} else if ( type === 2 ) {cameraControls.minDistance=1;cameraControls.maxDistance=30;}}// make variable available to browser consoleglobalThis.THREE=THREE;globalThis.camera=camera;globalThis.cameraControls=cameraControls;globalThis.setRange=setRange;</script></body></html>
I would expect smoothTime to apply to dollyInFixed all the time, even if there are user touch motions beforehand. I'd like to use dollyInFixed for auto movement when the user is idle.
Screenshots or Video
No response
Device
Mobile
OS
Android
Browser
Firefox
The text was updated successfully, but these errors were encountered:
Sorry for the delay, and thank you for your detailed report and the helpful demo.
Actually, it is a known problem. Currently, the camera controls cannot completely separate the smoothTime and draggingSmoothTime...
Describe the bug
@yomotsu 素敵なツールを作ってくれてありがとうございます。
cameraControls.smoothTime defaults to 0.25. You can set it to higher values for slower transitions of dollyInFixed in infinite dolly mode. But if, at any time, you use a pinch motion on mobile to move forwards or backwards, and then call dollyInFixed, the transition will execute with a smoothTime of 0.25, even if you try to set it again to a higher value.
This is happening on Android on a Samsung Galaxy A21 in both Firefox and the Samsung 'Internet' browser.
It doesn't happen on desktop.
To Reproduce
Steps to reproduce the behavior:
The code is below. It's just the infinite dolly example with two lines changed.
Code
Live example
https://somanyfaces.in/dollybug
Expected behavior
I would expect smoothTime to apply to dollyInFixed all the time, even if there are user touch motions beforehand. I'd like to use dollyInFixed for auto movement when the user is idle.
Screenshots or Video
No response
Device
Mobile
OS
Android
Browser
Firefox
The text was updated successfully, but these errors were encountered: