Compartilhar via


Função XMVector2Refract (directxmath.h)

Refrata um vetor 2D de incidente em um vetor normal 2D.

Sintaxe

XMVECTOR XM_CALLCONV XMVector2Refract(
  [in] FXMVECTOR Incident,
  [in] FXMVECTOR Normal,
  [in] float     RefractionIndex
) noexcept;

Parâmetros

[in] Incident

Vetor de incidente 2D a ser refratado.

[in] Normal

Vetor normal 2D pelo qual refratar o vetor de incidente.

[in] RefractionIndex

Índice de refração. Consulte Observações.

Valor retornado

Retorna o vetor de incidente refratado. Se o índice de refração e o ângulo entre o vetor de incidente e o normal forem de modo que o resultado seja uma reflexão interna total, a função retornará um vetor do formulário < 0.0f, 0.0f, indefinido, indefinido >.

Comentários

O pseudocódigo a seguir demonstra a operação da função:

XMVECTOR Result;

float t = (Incident.x * Normal.x + Incident.y * Normal.y); // dot(Incident, Normal);
float r = 1.0f - RefractionIndex * RefractionIndex * (1.0f - t * t);

if (r < 0.0f) // Total internal reflection
{
	Result.x = 0.0f;
	Result.y = 0.0f;
}
else
{
	float s = RefractionIndex * t + sqrt(r);
	Result.x = RefractionIndex * Incident.x - s * Normal.x;
	Result.y = RefractionIndex * Incident.y - s * Normal.y;
}

Result.z = undefined;
Result.w = undefined;

return Result;

O índice de refração é a proporção do índice de refração do meio que contém o vetor de incidente para o índice de refração da média que está sendo inserida (em que o índice de refração de um meio é, em si, a proporção da velocidade da luz em um vácuo para a velocidade da luz no meio).

Requisitos de plataforma

Microsoft Visual Studio 2010 ou Microsoft Visual Studio 2012 com o SDK do Windows para Windows 8. Com suporte para aplicativos da área de trabalho Win32, aplicativos da Windows Store e aplicativos Windows Phone 8.

Requisitos

   
Plataforma de Destino Windows
Cabeçalho directxmath.h (inclua DirectXMath.h)

Confira também

Funções geométricas de vetor 2D da Biblioteca DirectXMath

XMVector2RefractV