The post-process name
The size of the post-process and/or internal pass (0.5 means that your postprocess will have a width = canvas.width 0.5 and a height = canvas.height 0.5)
The camera that the post-process will be attached to
The mesh used to create the light scattering
The post-process quality, default 100
The babylon engine
If the post-process is reusable
The constructor needs a scene reference to initialize internal components. If "camera" is null a "scene" must be provided
Modify the scale of the post process to be the same as the viewport (default: false)
Sets the setAlphaBlendConstants of the babylon engine
Type of alpha mode to use when performing the post process (default: Engine.ALPHA_DISABLE)
Force textures to be a power of two (default: false)
Animations to be used for the post processing
The aspect ratio of the output texture.
If not undefined, the mesh position is computed from the attached node position
If the buffer needs to be cleared before applying the post process. (default: true) Should be set to false if shader will overwrite all previous pixels.
Clear color to use when screen clearing
Custom position of the mesh. Used if "useCustomMeshPosition" is set to "true"
Dissipates each sample's contribution in range [0, 1]
Controls the density of each sample
Enable Pixel Perfect mode where texture is not scaled to be power of 2. Can only be used on a single postprocess or on the last one of a chain. (default: false)
Array containing the excluded meshes not rendered in the internal pass
Controls the overall intensity of the post-process
Force the postprocess to be applied without taking in account viewport
Height of the texture to apply the post process on
The input texture for this post process and the output texture of the previous post process. When added to a pipeline the previous post process will render it's output into this texture and this texture will be used as textureSampler in the fragment shader of this post process.
List of inspectable custom properties (used by the Inspector)
If the post-process should inverse the light scattering direction
If the post process is supported.
The internal mesh used by the post-process
Name of the PostProcess.
A function that is added to the onActivateObservable
An event triggered when the postprocess is activated.
A function that is added to the onAfterRenderObservable
An event triggered after rendering the postprocess
A function that is added to the onApplyObservable
An event triggered when the postprocess applies its effect.
A function that is added to the onBeforeRenderObservable
An event triggered before rendering the postprocess
A function that is added to the onSizeChangedObservable
An event triggered when the postprocess changes its size.
Sampling mode used by the shader See https://doc.babylonjs.com/classes/3.1/texture
Number of sample textures (default: 1)
Gets the texel size of the postprocess. See https://en.wikipedia.org/wiki/Texel_(graphics)
Gets or sets the unique id of the post process
Set if the post-process should use a custom position for the light source (true) or the internal mesh position (false)
Controls the overall intensity of each sample
Width of the texture to apply the post process on
Activates the post process by intializing the textures to be used when executed. Notifies onActivateObservable. When this post process is used in a pipeline, this is call will bind the input texture of this post process to the output of the previous.
The camera that will be used in the post process. This camera will be used when calling onActivateObservable.
The source texture to be inspected to get the width and height if not specified in the post process constructor. (default: null)
If true, a depth and stencil buffer will be generated. (default: false)
The target texture that was bound to be written to.
Disposes the internal assets and detaches the post-process from the camera
Gets the camera which post process is applied to.
The camera the post process is applied to.
Returns the string "VolumetricLightScatteringPostProcess"
Returns the light position for light scattering effect
Vector3 The custom light position
The effect that is created when initializing the post process.
The created effect corresponding the the postprocess.
Returns the fragment url or shader name used in the post process.
the fragment url or name in the shader store.
Gets the engine which this post process belongs to.
The engine the post process was enabled with.
Returns the render target texture used by the post-process
the render target texture used by the post-process
Get a value indicating if the post-process is ready to be used
true if the post-process is ready (shader is compiled)
The post process is reusable if it can be used multiple times within one frame.
If the post process is reusable
invalidate frameBuffer to hint the postprocess to create a depth buffer
Sets the new light position for light scattering effect
The new custom light position
Updates the effect with the current post process compile time values and recompiles the shader.
Define statements that should be added at the beginning of the shader. (default: null)
Set of uniform variables that will be passed to the shader. (default: null)
Set of Texture2D variables that will be passed to the shader. (default: null)
The index parameters to be used for babylons include syntax "#include
Called when the shader has been compiled.
Called if there is an error when compiling a shader.
Reverses the effect of calling shareOutputWith and returns the post process back to its original state. This should be called if the post process that shares output with this post process is disabled/disposed.
Generated using TypeDoc