Freigeben über


XMVector2Refract-Funktion (directxmath.h)

Bricht einen Incident-2D-Vektor über einen normalen 2D-Vektor.

Syntax

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

Parameter

[in] Incident

2D-Incidentvektor, der gebrochen werden soll.

[in] Normal

2D normaler Vektor, um den Incidentvektor durchzubrechen.

[in] RefractionIndex

Index der Brechung. Siehe Bemerkungen.

Rückgabewert

Gibt den Vektor für den gebrochenen Vorfall zurück. Wenn der Brechungsindex und der Winkel zwischen dem Einfallvektor und dem Normalwert so sind, dass das Ergebnis eine gesamtinterne >Reflexion ist, gibt die Funktion einen Vektor der Form < 0.0f, 0.0f, undefined zurück.

Hinweise

Der folgende Pseudocode veranschaulicht den Betrieb der Funktion:

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;

Der Index der Brechung ist das Verhältnis des Index der Brechung des Mediums, das den Einfallvektor enthält, zum Index der Brechung des eingegebenen Mediums (wobei der Index der Brechung eines Mediums selbst das Verhältnis der Lichtgeschwindigkeit in einem Vakuum zur Lichtgeschwindigkeit im Medium ist).

Plattformanforderungen

Microsoft Visual Studio 2010 oder Microsoft Visual Studio 2012 mit dem Windows SDK für Windows 8. Unterstützt für Win32-Desktop-Apps, Windows Store-Apps und Windows Phone 8-Apps.

Anforderungen

   
Zielplattform Windows
Kopfzeile directxmath.h (einschließlich DirectXMath.h)

Weitere Informationen

Geometrische Funktionen der DirectXMath-Bibliothek mit 2D-Vektoren

XMVector2RefractV