ID3DXPRTEngine::ComputeVolumeSamplesDirectSH

Computes a projection of distant lighting into spherical harmonic (SH) basis vectors that represent incident radiance at specified locations.

HRESULT ComputeVolumeSamplesDirectSH(
  UINT OrderIn,
  UINT OrderOut,
  UINT NumVolSamples.xml,
  CONST D3DXVECTOR3 * pSampleLocs,
  LPD3DXPRTBUFFER pDataOut
);

Parameters

OrderIn
[in] Order of the SH representation of distant lighting. Must be in the range of D3DXSH_MINORDER to D3DXSH_MAXORDER, inclusive. The degree of the evaluation is OrderIn - 1.
OrderOut
[in] Order of the SH representation of local lighting. Must be in the range of D3DXSH_MINORDER to D3DXSH_MAXORDER, inclusive. The degree of the evaluation is OrderOut - 1.
NumVolSamples.xml
[in] Number of sample locations.
pSampleLocs
[in] Position for each sample.
pDataOut
[in, out] Pointer to an output ID3DXPRTBuffer object that projects the distant lighting into SH basis vectors. This buffer must have the proper number of color channels allocated for the simulation. This method generates OrderIn2 * OrderOut"2 scalars per channel at each sample location.

Return Values

If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be one of the following: D3DERR_INVALIDCALL, E_OUTOFMEMORY.

Remarks

This method computes how light from a distant source arrives at each point in space specified by pSampleLocs. The SH coefficients represent the mapping, at each pSampleLocs point, of source radiance to transferred incident radiance.

To use this method successfully, you must set sampling over a sphere with UseSphere = TRUE and UseCosine = FALSE in ID3DXPRTEngine::SetSamplingInfo; otherwise, this method will return an error with D3DERR_INVALIDCALL.

Requirements

Header: Declared in D3dx9mesh.h.

See Also

ID3DXPRTEngine::ComputeVolumeSamples