Cesium空间中AB两点A绕B点的地面法向量旋转任意角度后新的A点坐标(A’)

var A = new Cesium.Cartesian3(675679.994355399, 4532763.148054989, 4426298.210847025);
var B = new Cesium.Cartesian3(675520.4303984543, 4532803.837842555, 4425994.113846752);


// 计算B的地面法向量
var chicB = Cesium.Cartographic.fromCartesian(B);
chicB.height = 0;
var dB = Cesium.Cartographic.toCartesian(chicB);
var normaB = Cesium.Cartesian3.normalize(Cesium.Cartesian3.subtract(dB, B, new Cesium.Cartesian3()), new Cesium.Cartesian3());

// 构造基于B的法向量旋转90度的矩阵
var Q = Cesium.Quaternion.fromAxisAngle(normaB, Cesium.Math.toRadians(90));
var m3 = Cesium.Matrix3.fromQuaternion(Q);
var m4 = Cesium.Matrix4.fromRotationTranslation(m3);

// 计算A点相对B点的坐标A1
var A1 = Cesium.Cartesian3.subtract(A, B, new Cesium.Cartesian3());

//对A1应用旋转矩阵
var p = Cesium.Matrix4.multiplyByPoint(m4, A1, new Cesium.Cartesian3());
// 新的A的坐标
var p2 = Cesium.Cartesian3.add(p, B, new Cesium.Cartesian3());

viewer.entities.add({
    polyline: {
        positions: [B, A],
        width: 5,
        material: Cesium.Color.RED
    },
});


viewer.entities.add({
    polyline: {
        positions: [B, p2],
        width: 5,
        material: Cesium.Color.BLUE
    },

});

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值