Bayer.js 3.7 KB

12345678910111213141516171819202122232425262728293031323334
  1. import { TextureLoader } from 'three';
  2. import { Fn, int, ivec2, textureLoad } from 'three/tsl';
  3. /**
  4. * @module Bayer
  5. * @three_import import { bayer16 } from 'three/addons/tsl/math/Bayer.js';
  6. */
  7. let bayer16Texture = null;
  8. /**
  9. * This TSL function can be used to sample a Bayer16 texture which is a 16x16 texture with a Bayer Matrix pattern.
  10. * It can be used for dithering effects but also as an alternative to blue-noise. When used with Ray Marching
  11. * specifically in {@link VolumeNodeMaterial#offsetNode}, it reduces banding problem, thus being able to use
  12. * fewer steps without affecting the visuals as much.
  13. *
  14. * @tsl
  15. * @function
  16. * @param {Node<vec2>} uv - The uv to sample the bayer16 texture.
  17. * @return {Node<vec4>} The sampled bayer value.
  18. */
  19. export const bayer16 = Fn( ( [ uv ] ) => {
  20. if ( bayer16Texture === null ) {
  21. const bayer16Base64 = '';
  22. bayer16Texture = new TextureLoader().load( bayer16Base64 );
  23. }
  24. return textureLoad( bayer16Texture, ivec2( uv ).mod( int( 16 ) ) );
  25. } );