前言

一般情况下,我们可以直接通过Cesium.Cartesian3.distance(left, right)来获取两点的距离,但获取到的是两点的直线距离

const start = new Cesium.Cartesian3.fromDegrees(113,23);
const end = new Cesium.Cartesian3.fromDegrees(113,24);

const distance = Cesium.Cartesian3.distance(start,end); // 两点直线距离,单位:米

今天,我们将利用EllipsoidGeodesic这个类,来实现:

  1. 计算地球表面上两点之间的测地线距离
  2. 计算两个点之间指定距离上的插值点
  3. 获取线上指定位置的经纬度坐标,如:获取中点

正文

EllipsoidGeodesic(椭球测地线)是一种沿着地球表面的曲线,沿着该曲线移动最短距离,即大圆弧。而不是直接在三维空间中画线连接两个点,因为地球是一个椭球体,不能简单地将地球视为平面。
【CesiumJS入门】(9)获取地表两点的距离及中心点——EllipsoidGeodesic-LMLPHP

创建一个实例:

通过传入起始点和终点的经纬度坐标来创建一个 EllipsoidGeodesic 的实例:

const start = Cesium.Cartographic.fromDegrees(lon1, lat1);
const end = Cesium.Cartographic.fromDegrees(lon2, lat2);
const geodesic = new Cesium.EllipsoidGeodesic(start, end);

计算两点之间的距离:

可以使用 surfaceDistance 方法来计算地球表面上两个点之间的测地线距离(单位为米)。例如:

const distance = geodesic.surfaceDistance;

计算指定距离上的点:

可以使用 interpolateUsingSurfaceDistance 方法来计算两个点之间指定距离上的插值点。例如:

const distance = 1000; // 距离为1000米
const interpolatedPoint = geodesic.interpolateUsingSurfaceDistance(distance);

获取测地线上的点坐标:

可以使用 interpolateUsingFraction 方法来获取测地线上指定比例位置处的点的经纬度坐标。比例参数介于0到1之间,表示从起点到终点沿着测地线的距离比例。例如:

const fraction = 0.5; // 获取测地线中点的坐标
const point = geodesic.interpolateUsingFraction(fraction);

设置测地线的起点和终点

点的格式要求为:Cartographic

const newGeodesic = geodesic.setEndPoints(start, end);
08-26 01:37