Buckets:
ktongue/docker_container / simsite /frontend /node_modules /three /examples /jsm /shaders /AfterimageShader.js
| /** | |
| * Afterimage shader | |
| * I created this effect inspired by a demo on codepen: | |
| * https://codepen.io/brunoimbrizi/pen/MoRJaN?page=1& | |
| */ | |
| const AfterimageShader = { | |
| name: 'AfterimageShader', | |
| uniforms: { | |
| 'damp': { value: 0.96 }, | |
| 'tOld': { value: null }, | |
| 'tNew': { value: null } | |
| }, | |
| vertexShader: /* glsl */` | |
| varying vec2 vUv; | |
| void main() { | |
| vUv = uv; | |
| gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 ); | |
| }`, | |
| fragmentShader: /* glsl */` | |
| uniform float damp; | |
| uniform sampler2D tOld; | |
| uniform sampler2D tNew; | |
| varying vec2 vUv; | |
| vec4 when_gt( vec4 x, float y ) { | |
| return max( sign( x - y ), 0.0 ); | |
| } | |
| void main() { | |
| vec4 texelOld = texture2D( tOld, vUv ); | |
| vec4 texelNew = texture2D( tNew, vUv ); | |
| texelOld *= damp * when_gt( texelOld, 0.1 ); | |
| gl_FragColor = max(texelNew, texelOld); | |
| }` | |
| }; | |
| export { AfterimageShader }; | |
Xet Storage Details
- Size:
- 903 Bytes
- Xet hash:
- 15150bae65e7b06894e672be5fb953709a62d5d10144855d3db909e5c70fe7a4
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.