UNPKG

pixi.js

Version:

<p align="center"> <a href="https://pixijs.com" target="_blank" rel="noopener noreferrer"> <img height="150" src="https://files.pixijs.download/branding/pixijs-logo-transparent-dark.svg?v=1" alt="PixiJS logo"> </a> </p> <br/> <p align="center">

115 lines (112 loc) 3.26 kB
import { GlProgram } from '../../../rendering/renderers/gl/shader/GlProgram.mjs'; import { GpuProgram } from '../../../rendering/renderers/gpu/shader/GpuProgram.mjs'; import { UniformGroup } from '../../../rendering/renderers/shared/shader/UniformGroup.mjs'; import { Filter } from '../../Filter.mjs'; import vertex from '../defaultFilter.vert.mjs'; import fragment from './noise.frag.mjs'; import source from './noise.wgsl.mjs'; "use strict"; const _NoiseFilter = class _NoiseFilter extends Filter { /** * @param options - The options of the noise filter. */ constructor(options = {}) { options = { ..._NoiseFilter.defaultOptions, ...options }; const gpuProgram = GpuProgram.from({ vertex: { source, entryPoint: "mainVertex" }, fragment: { source, entryPoint: "mainFragment" } }); const glProgram = GlProgram.from({ vertex, fragment, name: "noise-filter" }); const { noise, seed, ...rest } = options; super({ ...rest, gpuProgram, glProgram, resources: { noiseUniforms: new UniformGroup({ uNoise: { value: 1, type: "f32" }, uSeed: { value: 1, type: "f32" } }) } }); this.noise = noise; this.seed = seed ?? Math.random(); } /** * The amount of noise to apply to the filtered content. * * This value controls the intensity of the random noise effect: * - Values close to 0 produce subtle noise * - Values around 0.5 produce moderate noise * - Values close to 1 produce strong noise * @default 0.5 * @example * ```ts * const noiseFilter = new NoiseFilter(); * * // Set to subtle noise * noiseFilter.noise = 0.2; * * // Set to maximum noise * noiseFilter.noise = 1.0; * ``` */ get noise() { return this.resources.noiseUniforms.uniforms.uNoise; } set noise(value) { this.resources.noiseUniforms.uniforms.uNoise = value; } /** * The seed value used for random noise generation. * * This value determines the noise pattern: * - Using the same seed will generate identical noise patterns * - Different seeds produce different but consistent patterns * - `Math.random()` can be used for random patterns * @default Math.random() * @example * ```ts * const noiseFilter = new NoiseFilter(); * * // Use a fixed seed for consistent noise * noiseFilter.seed = 12345; * * // Generate new random pattern * noiseFilter.seed = Math.random(); * ``` */ get seed() { return this.resources.noiseUniforms.uniforms.uSeed; } set seed(value) { this.resources.noiseUniforms.uniforms.uSeed = value; } }; /** * The default configuration options for the NoiseFilter. * * These values will be used when no specific options are provided to the constructor. * You can override any of these values by passing your own options object. * @example * ```ts * NoiseFilter.defaultOptions.noise = 0.7; // Change default noise to 0.7 * const filter = new NoiseFilter(); // Will use noise 0.7 by default * ``` */ _NoiseFilter.defaultOptions = { noise: 0.5 }; let NoiseFilter = _NoiseFilter; export { NoiseFilter }; //# sourceMappingURL=NoiseFilter.mjs.map