Click or drag to resize
AB4D logo

SeparableKernelPostProcess Class

SeparableKernelPostProcess applies horizontal or vertical gaussian post process. It uses array of offsets and weights to define how the pixels are processed (size of the arrays is defined by the filterSize specified in the constructor - max value is 15). This post process usually needs to be rendered in two passes - one vertical and one horizontal.
Inheritance Hierarchy
System.Object
  Ab3d.DirectX.DXResourceBase
    Ab3d.DirectX.SharedDXResource
      Ab3d.DirectX.SharedDXDeviceResource
        Ab3d.DirectX.PostProcessing.PostProcessBase
          Ab3d.DirectX.PostProcessing.StandardPostProcess
            Ab3d.DirectX.PostProcessing.SimplePixelShaderPostProcess
              Ab3d.DirectX.PostProcessing.SeparableKernelPostProcess
                Ab3d.DirectX.PostProcessing.DownSampleWithFilerPostProcess
                Ab3d.DirectX.PostProcessing.GaussianBlurPostProcess

Namespace: Ab3d.DirectX.PostProcessing
Assembly: Ab3d.DXEngine (in Ab3d.DXEngine.dll) Version: 7.1.9105.2048 (1.0.0.0)
Syntax
C#
public abstract class SeparableKernelPostProcess : SimplePixelShaderPostProcess

The SeparableKernelPostProcess type exposes the following members.

Constructors
 NameDescription
Public methodSeparableKernelPostProcess(Int32) Initializes a new instance of the SeparableKernelPostProcess class.
Public methodSeparableKernelPostProcess(Boolean, Int32) Initializes a new instance of the SeparableKernelPostProcess class.
Top
Properties
 NameDescription
Public propertyFilterSize Gets or sets the size of the filter - number of pixels that are read to get the color produces by this post-process.
Public propertyIsVerticalPass Gets a boolean that specifies if vertical rendering pass is applied. If false than horizontal pass is applied. This value is set in constructor. Note that in order to render this post process fully, it needs to run in two passes - once as vertical and once as horizontal post process.
Public propertyTextureSize Gets or sets the size of the texture.
Top
Methods
 NameDescription
Public methodRender Render renders the post process with using the sourceShaderResourceView as the source texture. It rendered the output to the CurrentRenderTargetView defined in the renderingContext.
(Overrides SimplePixelShaderPostProcess.Render(RenderingContext, ShaderResourceView))
Top
Fields
 NameDescription
Public fieldMaxFilterSize MaxFilterSize defines the maximum filter size that is supported by this post-process.
Top
Remarks

SeparableKernelPostProcess applies horizontal or vertical gaussian blur post process. It uses array of offsets and weights to define how the pixels are processed.

Offsets define how far from the texture coordinate we sample pixel. Weights define how much weight this pixel has in the final color.

The following pixel shader is used for this post process:

C#
float4 output = (float4)0.0f;

for (int i = 0; i < 15; i++)
    output += gTexture.Sample(gSampler, psIn.textCoord + gOffsets[i]) * gWeights[i];

return output;
See Also