DotScreenPass.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import {
  2. ShaderMaterial,
  3. UniformsUtils
  4. } from 'three';
  5. import { Pass, FullScreenQuad } from './Pass.js';
  6. import { DotScreenShader } from '../shaders/DotScreenShader.js';
  7. class DotScreenPass extends Pass {
  8. constructor( center, angle, scale ) {
  9. super();
  10. const shader = DotScreenShader;
  11. this.uniforms = UniformsUtils.clone( shader.uniforms );
  12. if ( center !== undefined ) this.uniforms[ 'center' ].value.copy( center );
  13. if ( angle !== undefined ) this.uniforms[ 'angle' ].value = angle;
  14. if ( scale !== undefined ) this.uniforms[ 'scale' ].value = scale;
  15. this.material = new ShaderMaterial( {
  16. uniforms: this.uniforms,
  17. vertexShader: shader.vertexShader,
  18. fragmentShader: shader.fragmentShader
  19. } );
  20. this.fsQuad = new FullScreenQuad( this.material );
  21. }
  22. render( renderer, writeBuffer, readBuffer /*, deltaTime, maskActive */ ) {
  23. this.uniforms[ 'tDiffuse' ].value = readBuffer.texture;
  24. this.uniforms[ 'tSize' ].value.set( readBuffer.width, readBuffer.height );
  25. if ( this.renderToScreen ) {
  26. renderer.setRenderTarget( null );
  27. this.fsQuad.render( renderer );
  28. } else {
  29. renderer.setRenderTarget( writeBuffer );
  30. if ( this.clear ) renderer.clear();
  31. this.fsQuad.render( renderer );
  32. }
  33. }
  34. dispose() {
  35. this.material.dispose();
  36. this.fsQuad.dispose();
  37. }
  38. }
  39. export { DotScreenPass };