Método IDirect3D9::CheckDepthStencilMatch (d3d9helper.h)
Determina se um formato de estêncil de profundidade é compatível com um formato de destino de renderização em um modo de exibição específico.
Sintaxe
HRESULT CheckDepthStencilMatch(
[in] UINT Adapter,
[in] D3DDEVTYPE DeviceType,
[in] D3DFORMAT AdapterFormat,
[in] D3DFORMAT RenderTargetFormat,
[in] D3DFORMAT DepthStencilFormat
);
Parâmetros
[in] Adapter
Tipo: UINT
Número ordinal que indica o adaptador de exibição para consulta. D3DADAPTER_DEFAULT é sempre o adaptador de exibição primário.
[in] DeviceType
Tipo: D3DDEVTYPE
Membro do D3DDEVTYPE tipo enumerado, identificando o tipo de dispositivo.
[in] AdapterFormat
Tipo: D3DFORMAT
Membro do D3DFORMAT tipo enumerado, identificando o formato do modo de exibição no qual o adaptador será colocado.
[in] RenderTargetFormat
Tipo: D3DFORMAT
Membro do D3DFORMAT tipo enumerado, identificando o formato da superfície de destino de renderização a ser testada.
[in] DepthStencilFormat
Tipo: D3DFORMAT
Membro do D3DFORMAT tipo enumerado, identificando o formato da superfície de estêncil de profundidade a ser testada.
Retornar valor
Tipo: HRESULT
Se o formato de estêncil de profundidade for compatível com o formato render-target no modo de exibição, esse método retornará D3D_OK. D3DERR_INVALIDCALL poderá ser retornado se um ou mais dos parâmetros forem inválidos. Se um formato de estêncil de profundidade não for compatível com o destino de renderização no modo de exibição, esse método retornará D3DERR_NOTAVAILABLE.
Comentários
Esse método é fornecido para permitir que os aplicativos funcionem com hardware, exigindo que determinados formatos de profundidade só possam funcionar com determinados formatos de destino de renderização.
O comportamento desse método foi alterado para o DirectX 8.1. Esse método agora presta atenção aos formatos de estêncil de profundidade D24x8 e D32. A versão anterior presumia que esses formatos sempre seriam utilizáveis com destinos de renderização de 32 ou 16 bits. Agora, esse método retornará D3D_OK para esses formatos somente se o dispositivo for capaz de operações de profundidade mista.
O fragmento de código a seguir mostra como você pode usar CheckDeviceFormat para validar um formato de estêncil de profundidade.
BOOL IsDepthFormatOk(D3DFORMAT DepthFormat,
D3DFORMAT AdapterFormat,
D3DFORMAT BackBufferFormat)
{
// Verify that the depth format exists
HRESULT hr = pD3D->CheckDeviceFormat(D3DADAPTER_DEFAULT,
D3DDEVTYPE_HAL,
AdapterFormat,
D3DUSAGE_DEPTHSTENCIL,
D3DRTYPE_SURFACE,
DepthFormat);
if(FAILED(hr)) return FALSE;
// Verify that the depth format is compatible
hr = pD3D->CheckDepthStencilMatch(D3DADAPTER_DEFAULT,
D3DDEVTYPE_HAL,
AdapterFormat,
BackBufferFormat,
DepthFormat);
return SUCCEEDED(hr);
}
A chamada anterior retornará FALSE se DepthFormat não puder ser usado em conjunto com AdapterFormat e BackBufferFormat.
Requisitos
Requisito | Valor |
---|---|
Plataforma de Destino | Windows |
Cabeçalho | d3d9helper.h (inclua D3D9.h) |
Biblioteca | D3D9.lib |