ColorifyShader.js 834 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. import {
  2. Color
  3. } from 'three';
  4. /**
  5. * @module ColorifyShader
  6. * @three_import import { ColorifyShader } from 'three/addons/shaders/ColorifyShader.js';
  7. */
  8. /**
  9. * Colorify shader.
  10. *
  11. * @constant
  12. * @type {ShaderMaterial~Shader}
  13. */
  14. const ColorifyShader = {
  15. name: 'ColorifyShader',
  16. uniforms: {
  17. 'tDiffuse': { value: null },
  18. 'color': { value: new Color( 0xffffff ) }
  19. },
  20. vertexShader: /* glsl */`
  21. varying vec2 vUv;
  22. void main() {
  23. vUv = uv;
  24. gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
  25. }`,
  26. fragmentShader: /* glsl */`
  27. uniform vec3 color;
  28. uniform sampler2D tDiffuse;
  29. varying vec2 vUv;
  30. void main() {
  31. vec4 texel = texture2D( tDiffuse, vUv );
  32. float v = luminance( texel.xyz );
  33. gl_FragColor = vec4( v * color, texel.w );
  34. }`
  35. };
  36. export { ColorifyShader };
粤ICP备19079148号