threepipe
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

OrbitControls3.ts 2.3KB

3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
3 vuotta sitten
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import {OrbitControls} from 'three/examples/jsm/controls/OrbitControls.js'
  2. import {IUiConfigContainer, uiInput, UiObjectConfig, uiPanelContainer, uiToggle, uiVector} from 'uiconfig.js'
  3. import {serialize} from 'ts-browser-helpers'
  4. import {ICameraControls} from '../../core'
  5. import {Vector3} from 'three'
  6. export type TOrbitControlsEvents = 'change' | 'end' | 'start'
  7. @uiPanelContainer('Orbit Controls')
  8. export class OrbitControls3 extends OrbitControls implements IUiConfigContainer, ICameraControls<TOrbitControlsEvents> {
  9. uiConfig?: UiObjectConfig<void, 'panel'>
  10. @serialize() type = 'OrbitControls'
  11. @uiToggle() enabled = true
  12. @uiToggle() @serialize() dollyZoom = false
  13. @uiToggle() @serialize() enableDamping = true
  14. @uiInput() @serialize() dampingFactor = 0.08
  15. @uiToggle() @serialize() autoRotate = false
  16. @uiInput() @serialize() autoRotateSpeed = 2.0
  17. @uiToggle() @serialize() enableZoom = true
  18. @uiInput() @serialize() zoomSpeed = 0.15
  19. @uiInput() @serialize() maxZoomSpeed = 0.20
  20. @uiToggle() @serialize() enableRotate = true
  21. @uiInput() @serialize() rotateSpeed = 2.0
  22. @uiToggle() @serialize() enablePan = true
  23. @uiInput() @serialize() panSpeed = 1.0
  24. @uiInput() @serialize() autoPushTarget = false
  25. @uiInput() @serialize() autoPullTarget = false
  26. @uiInput() @serialize() minDistance = 0.35
  27. @uiInput() @serialize() maxDistance = 1000
  28. @uiInput() @serialize() minZoom = 0.01
  29. @uiInput() @serialize() maxZoom = 1000
  30. @uiInput() @serialize() minPolarAngle = 0
  31. @uiInput() @serialize() maxPolarAngle = Math.PI
  32. @uiInput() @serialize() minAzimuthAngle = -10000 // should be -Infinity but this breaks the UI
  33. @uiInput() @serialize() maxAzimuthAngle = 10000 // should be Infinity but this breaks the UI
  34. @uiVector() @serialize() clampMin = new Vector3(-10000, -10000, -10000) // should be -Infinity but this breaks the UI
  35. @uiVector() @serialize() clampMax = new Vector3(10000, 10000, 10000) // should be Infinity but this breaks the UI
  36. // @uiToggle()
  37. @serialize() screenSpacePanning = true
  38. // @uiInput()
  39. @serialize() keyPanSpeed = 7.0
  40. throttleUpdate = 60 // throttle to 60 updates per second (implemented in OrbitControls.js.update() method)
  41. // todo add to three-ts-types
  42. stopDamping!: () => void
  43. }