IDirect3DDevice9::ProcessVertices method (d3d9.h)
Applies the vertex processing defined by the vertex shader to the set of input data streams, generating a single stream of interleaved vertex data to the destination vertex buffer.
Syntax
HRESULT ProcessVertices(
[in] UINT SrcStartIndex,
[in] UINT DestIndex,
[in] UINT VertexCount,
[in] IDirect3DVertexBuffer9 *pDestBuffer,
[in] IDirect3DVertexDeclaration9 *pVertexDecl,
[in] DWORD Flags
);
Parameters
[in] SrcStartIndex
Type: UINT
Index of first vertex to load.
[in] DestIndex
Type: UINT
Index of first vertex in the destination vertex buffer into which the results are placed.
[in] VertexCount
Type: UINT
Number of vertices to process.
[in] pDestBuffer
Type: IDirect3DVertexBuffer9*
Pointer to an IDirect3DVertexBuffer9 interface, the destination vertex buffer representing the stream of interleaved vertex data.
[in] pVertexDecl
Type: IDirect3DVertexDeclaration9*
Pointer to an IDirect3DVertexDeclaration9 interface that represents the output vertex data declaration. When vertex shader 3.0 or above is set as the current vertex shader, the output vertex declaration must be present.
[in] Flags
Type: DWORD
Processing options. Set this parameter to 0 for default processing. Set to D3DPV_DONOTCOPYDATA to prevent the system from copying vertex data not affected by the vertex operation into the destination buffer. The D3DPV_DONOTCOPYDATA value may be combined with one or more D3DLOCK values appropriate for the destination buffer.
Return value
Type: HRESULT
If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.
Remarks
The order of operations for this method is as follows:
- Transform vertices to projection space using the world + view + projection matrix.
- Compute screen coordinates using viewport settings.
- If clipping is enabled, compute clipping codes and store them in an internal buffer, associated with the destination vertex buffer. If a vertex is inside the viewing frustum, its screen coordinates are computed. If the vertex is outside the viewing frustum, the vertex is stored in the destination vertex buffer in projection space coordinates.
- Other notes: The user does not have access to the internal clip code buffer. No clipping is done on triangles or any other primitives.
When Direct3D generates texture coordinates, or copies or transforms input texture coordinates, and the output texture coordinate format defines more texture coordinate components than Direct3D generates, Direct3D does not change these extra components.
Requirements
Requirement | Value |
---|---|
Target Platform | Windows |
Header | d3d9.h (include D3D9.h) |
Library | D3D9.lib |
See also
Device Types and Vertex Processing Requirements (Direct3D 9)