如何根据经纬度计算地面上某点在XYZ空间直角坐标系中的坐标

/**
     * @param r: number 到地心的距离
     * @param lon: number 经度
     * @param lat: number 纬度
     * @return {[number, number, number]}
     */
    getXYZByLonLat = (r, lon, lat) => {
        const {sin, cos, PI} = Math;
        const lonRadian = lon / 180 * PI;
        const latRadian = lat / 180 * PI;

        const y = r * sin(latRadian); // 在经线圈平面上, 计算y

        const rOnEquatorialPlane = r * cos(latRadian); // 在赤道面上, 计算r的投影距离
        const x = rOnEquatorialPlane * sin(lonRadian); // 在俯视图中, 计算x
        const z = rOnEquatorialPlane * cos(lonRadian); // 在俯视图中, 计算z

        /**
         x = R * cos(lat) * sin(lon)
         y = R * sin(lat)
         z = R * cos(lat) * cos(lon)
         */
        return [x, y, z];
    };

相关文章:

  • 2021-10-16
  • 2021-07-06
  • 2022-01-29
  • 2022-12-23
  • 2022-12-23
  • 2021-11-27
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-07-04
  • 2022-12-23
  • 2021-11-26
  • 2021-12-19
  • 2022-12-23
  • 2021-11-27
  • 2022-12-23
相关资源
相似解决方案