cesium 根据两个点计算距离和角度

56 篇文章 1 订阅
文章讲述了在Cesium中计算两点p1和p2在已知世界坐标系中的夹角的方法,介绍了使用矩阵变换和Math.atan2进行归一化向量计算的两种方式,并指出两者结果一致。
摘要由CSDN通过智能技术生成

已知世界坐标系中的两个点p1、p2,求p1和p2的角度。原理是以p1为原点,建立一个enu坐标系,求出在这个相对坐标系中p1到p2的向量,归一化得到单位向量localVector,再通过Math.atan2计算出这个localVector和x轴的夹角,即是p1到p2的夹角。

方法一:先求出p1、p2在相对坐标系中的坐标local1、local2,相减得到向量localVector,归一化得到单位向量。

let localToWorldMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(p1);
let worldToLocalMatrix = Cesium.Matrix4.inverse(localToWorldMatrix, new Cesium.Matrix4());

// 计算 localVector
let local1 = Cesium.Matrix4.multiplyByPoint(
    worldToLocalMatrix,
    p1,
    new Cesium.Cartesian3()
);
let local2 = Cesium.Matrix4.multiplyByPoint(
    worldToLocalMatrix,
    p2,
    new Cesium.Cartesian3()
);
let localVector = Cesium.Cartesian3.subtract(local2, local1, new Cesium.Cartesian3());

// localVector 向量归一化
let direction = Cesium.Cartesian3.normalize(localVector, new Cesium.Cartesian3());
let angleToX = Math.atan2(direction.y, direction.x);
let heading = Cesium.Math.toDegrees(angleToX);

方法二:先用p1、p2在世界坐标系中相减得到世界坐标下的向量worldVector,再用以p1为原点得到的矩阵的逆矩阵,计算出worldVector在相对坐标系下的向量值,归一化得到单位向量。

let localToWorldMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(p1);
let worldToLocalMatrix = Cesium.Matrix4.inverse(localToWorldMatrix, new Cesium.Matrix4());

// 计算 localVector
let worldVector = Cesium.Cartesian3.subtract(p2, p1, new Cesium.Cartesian3());
let localVector = Cesium.Matrix4.multiplyByPointAsVector(worldToLocalMatrix, worldVector, new Cesium.Cartesian3());

// localVector 向量归一化
let direction = Cesium.Cartesian3.normalize(localVector, new Cesium.Cartesian3());
let angleToX = Math.atan2(direction.y, direction.x);
let heading = Cesium.Math.toDegrees(angleToX);

可以看出,两种方法就是计算localVector的方式不同,结果是一致的。

1、红线为以1为原点建立的相对坐标系的x轴正方向。

2、Math.atan2是内置方法

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值