three.map.control

網址:https://github.com/anvaka/three.map.controlreact

在threejs羣裏發現的一個頗有意思的問題以前沒有接觸過:git

存在的問題github

 我在微信小遊戲中,用orbit也會出現計算錯誤的狀況,動一下就不見了。 
解決辦法
 發現了, 原來是小遊戲裏面獲取不到 element.clientWidth, 要替換成 window.innerWidth 

three.map.control

Mobile friendly three.js camera that mimics 2d maps navigation with pan and zoom.api

DEMO微信

Features

  • Touch friendly. Drag scene around with single finger touch, or zoom it with standard pinch gesture.

touch friendly

  • Zoom into point. Use your mouse wheel to zoom into particular point on the scene.
  • Easing. When you pan around, the movement does not stop immediately. Smooth kinetic panning gives natural feel to it.

easing

  • Tiny. It's less than 400 lines of documented code.

usage

// let's say you have a standard THREE.js PerspectiveCamera: var camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 3000 ); // To turn on a map-like navigation: var createPanZoom = require('three.map.control'); // We assume that three.js scene is hosted inside DOM element `container` var panZoom = createPanZoom(camera, container); // That's it. panZoom wil now listen to events from `container`. You can pan and // zoom with your mouse or fingers (on touch device) // If you want to dispose three.js scene, make sure to call: panZoom.dispose();

events

// the panZoom api fires events when something happens, // so that you can react to user actions: panZoom.on('panstart', function() { // fired when users begins panning (dragging) the surface console.log('panstart fired'); }); panZoom.on('panend', function() { // fired when user stpos panning (dragging) the surface console.log('panend fired'); }); panZoom.on('beforepan', function(panPayload) { // fired when camera position will be changed. console.log('going to move camera.position.x by: ' + panPayload.dx); console.log('going to move camera.position.y by: ' + panPayload.dy); }); panZoom.on('beforezoom', function(panPayload) { // fired when befor zoom in/zoom out console.log('going to move camera.position.x by: ' + panPayload.dx); console.log('going to move camera.position.y by: ' + panPayload.dy); console.log('going to move camera.position.z by: ' + panPayload.dz); });

license

MITapp

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息