今天又遇到了球面坐标系转换成笛卡尔坐标系,其实是一个很简单的问题,记录一下以便以后查看。
假设球面坐标系中的P点坐标为(r,
θ
\theta
θ,
φ
\varphi
φ)有时候球面坐标系中的三个坐标会使用另一种方式表达:
r:无疑就是球体的半径
θ
\theta
θ:称为倾斜角(inclination)
φ
\varphi
φ:称为方位角(azimuth)
将球体坐标系转换为笛卡尔坐标系(也就是常见的xyz坐标系):
x=rsin(
θ
\theta
θ)cos(
φ
\varphi
φ)
y=rsin(
θ
\theta
θ)sin(
φ
\varphi
φ)
z=r*cos(
θ
\theta
θ)
用C#代码写出来:
public Vector3 ToCartesian()
{
Vector3 cartesian = new Vector3();
cartesian.z = radius * Mathf.Sin(inclination) * Mathf.Cos(azimuth);
cartesian.x = radius * Mathf.Sin(inclination) * Mathf.Sin(azimuth);
cartesian.y = radius * Mathf.Cos(inclination);
return cartesian;
}