前言
一般情况下,我们可以直接通过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这个类,来实现:
- 计算地球表面上两点之间的测地线距离
- 计算两个点之间指定距离上的插值点
- 获取线上指定位置的经纬度坐标,如:获取中点
正文
EllipsoidGeodesic(椭球测地线)是一种沿着地球表面的曲线,沿着该曲线移动最短距离,即大圆弧。而不是直接在三维空间中画线连接两个点,因为地球是一个椭球体,不能简单地将地球视为平面。
创建一个实例:
通过传入起始点和终点的经纬度坐标来创建一个 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);