CubeCamera.js 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import { Object3D } from '../core/Object3D';
  2. import { WebGLRenderTargetCube } from '../renderers/WebGLRenderTargetCube';
  3. import { LinearFilter, RGBFormat } from '../constants';
  4. import { Vector3 } from '../math/Vector3';
  5. import { PerspectiveCamera } from './PerspectiveCamera';
  6. /**
  7. * Camera for rendering cube maps
  8. * - renders scene into axis-aligned cube
  9. *
  10. * @author alteredq / http://alteredqualia.com/
  11. */
  12. function CubeCamera( near, far, cubeResolution ) {
  13. Object3D.call( this );
  14. this.type = 'CubeCamera';
  15. var fov = 90, aspect = 1;
  16. var cameraPX = new PerspectiveCamera( fov, aspect, near, far );
  17. cameraPX.up.set( 0, - 1, 0 );
  18. cameraPX.lookAt( new Vector3( 1, 0, 0 ) );
  19. this.add( cameraPX );
  20. var cameraNX = new PerspectiveCamera( fov, aspect, near, far );
  21. cameraNX.up.set( 0, - 1, 0 );
  22. cameraNX.lookAt( new Vector3( - 1, 0, 0 ) );
  23. this.add( cameraNX );
  24. var cameraPY = new PerspectiveCamera( fov, aspect, near, far );
  25. cameraPY.up.set( 0, 0, 1 );
  26. cameraPY.lookAt( new Vector3( 0, 1, 0 ) );
  27. this.add( cameraPY );
  28. var cameraNY = new PerspectiveCamera( fov, aspect, near, far );
  29. cameraNY.up.set( 0, 0, - 1 );
  30. cameraNY.lookAt( new Vector3( 0, - 1, 0 ) );
  31. this.add( cameraNY );
  32. var cameraPZ = new PerspectiveCamera( fov, aspect, near, far );
  33. cameraPZ.up.set( 0, - 1, 0 );
  34. cameraPZ.lookAt( new Vector3( 0, 0, 1 ) );
  35. this.add( cameraPZ );
  36. var cameraNZ = new PerspectiveCamera( fov, aspect, near, far );
  37. cameraNZ.up.set( 0, - 1, 0 );
  38. cameraNZ.lookAt( new Vector3( 0, 0, - 1 ) );
  39. this.add( cameraNZ );
  40. var options = { format: RGBFormat, magFilter: LinearFilter, minFilter: LinearFilter, name: "cubeCamera" };
  41. this.renderTarget = new WebGLRenderTargetCube( cubeResolution, cubeResolution, options );
  42. this.updateCubeMap = function ( renderer, scene ) {
  43. if ( this.parent === null ) this.updateMatrixWorld();
  44. var renderTarget = this.renderTarget;
  45. var generateMipmaps = renderTarget.texture.generateMipmaps;
  46. renderTarget.texture.generateMipmaps = false;
  47. renderTarget.activeCubeFace = 0;
  48. renderer.render( scene, cameraPX, renderTarget );
  49. renderTarget.activeCubeFace = 1;
  50. renderer.render( scene, cameraNX, renderTarget );
  51. renderTarget.activeCubeFace = 2;
  52. renderer.render( scene, cameraPY, renderTarget );
  53. renderTarget.activeCubeFace = 3;
  54. renderer.render( scene, cameraNY, renderTarget );
  55. renderTarget.activeCubeFace = 4;
  56. renderer.render( scene, cameraPZ, renderTarget );
  57. renderTarget.texture.generateMipmaps = generateMipmaps;
  58. renderTarget.activeCubeFace = 5;
  59. renderer.render( scene, cameraNZ, renderTarget );
  60. renderer.setRenderTarget( null );
  61. };
  62. }
  63. CubeCamera.prototype = Object.create( Object3D.prototype );
  64. CubeCamera.prototype.constructor = CubeCamera;
  65. export { CubeCamera };