StereoEffect.js 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import {
  2. StereoCamera,
  3. Vector2
  4. } from 'three';
  5. class StereoEffect {
  6. constructor( renderer ) {
  7. const _stereo = new StereoCamera();
  8. _stereo.aspect = 0.5;
  9. const size = new Vector2();
  10. this.setEyeSeparation = function ( eyeSep ) {
  11. _stereo.eyeSep = eyeSep;
  12. };
  13. this.setSize = function ( width, height ) {
  14. renderer.setSize( width, height );
  15. };
  16. this.render = function ( scene, camera ) {
  17. if ( scene.matrixWorldAutoUpdate === true ) scene.updateMatrixWorld();
  18. if ( camera.parent === null && camera.matrixWorldAutoUpdate === true ) camera.updateMatrixWorld();
  19. _stereo.update( camera );
  20. const currentAutoClear = renderer.autoClear;
  21. renderer.getSize( size );
  22. renderer.autoClear = false;
  23. renderer.clear();
  24. renderer.setScissorTest( true );
  25. renderer.setScissor( 0, 0, size.width / 2, size.height );
  26. renderer.setViewport( 0, 0, size.width / 2, size.height );
  27. renderer.render( scene, _stereo.cameraL );
  28. renderer.setScissor( size.width / 2, 0, size.width / 2, size.height );
  29. renderer.setViewport( size.width / 2, 0, size.width / 2, size.height );
  30. renderer.render( scene, _stereo.cameraR );
  31. renderer.setScissorTest( false );
  32. renderer.autoClear = currentAutoClear;
  33. };
  34. }
  35. }
  36. export { StereoEffect };
粤ICP备19079148号