Cesium-鼠标拾取椭球、地形、模型坐标点详解

10 篇文章 3 订阅

前言

Cesium 中的三维坐标可分为三种情况:椭球表面、地形和模型。

获取椭球体表面的经纬度坐标(方法一)

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);  
handler.setInputAction(function(evt) { 
    var cartesian = viewer.camera.pickEllipsoid(evt.position, viewer.scene.globe.ellipsoid);  
    var cartographic = Cesium.Cartographic.fromCartesian(cartesian);  
    var lng = Cesium.Math.toDegrees(cartographic.longitude); // 经度值  
    var lat = Cesium.Math.toDegrees(cartographic.latitude); // 纬度值  
    var mapPosition = {
        x: lng, 
        y: lat,
        z: cartographic.height // cartographic.height 的值始终为零
    };
}, Cesium.ScreenSpaceEventType.LEFT_CLICK); 

获取相机高度可以通过此法获得:

// 获取相机的高度
height = Math.ceil(viewer.camera.positionCartographic.height);

获取椭球体表面的经纬度坐标(方法二)

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
// 设置鼠标移动事件的处理函数,这里负责监听x, y坐标值变化
handler.setInputAction(function(evt) {
    // 得到当前三维场景的椭球体,即地球
    var ellipsoid = scene.globe.ellipsoid;
    // 通过指定的椭球或者地图对应的坐标系,将鼠标的二维坐标转换为对应椭球体三维坐标
    cartesian = viewer.camera.pickEllipsoid(evt.endPosition, ellipsoid);
    // 将笛卡尔坐标转换为地理坐标
    var cartographic = ellipsoid.cartesianToCartographic(cartesian);
    // 将弧度转换为度的十进制表示
    lng = Cesium.Math.toDegrees(cartographic.longitude);
    lat = Cesium.Math.toDegrees(cartographic.latitude);

}, Cesium.ScreenSpaceEventType.MOUSE_MOVE)

获取地形表面的经纬度高程坐标(方法一)

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);  
handler.setInputAction(function(evt) {  
    var ray = viewer.camera.getPickRay(evt.position);  
    var cartesian = viewer.scene.globe.pick(ray, viewer.scene); 
    var cartographic = Cesium.Cartographic.fromCartesian(cartesian); 
    var lng = Cesium.Math.toDegrees(cartographic.longitude); // 经度值  
    var lat = Cesium.Math.toDegrees(cartographic.latitude); // 纬度值  
    var mapPosition = {
        x: lng,
        y: lat,
        z: cartographic.height // cartographic.height的值为地形高度 
    }; 
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);

获取地形表面的经纬度高程坐标(方法二)

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);  
handler.setInputAction(function(evt) {  
    var ray = viewer.camera.getPickRay(evt.position);  
    var cartesian = viewer.scene.globe.pick(ray, viewer.scene);  
    var cartographic = Cesium.Cartographic.fromCartesian(cartesian);  
    var lng = Cesium.Math.toDegrees(cartographic.longitude); // 经度值  
    var lat = Cesium.Math.toDegrees(cartographic.latitude); // 纬度值  
    // height 结果与 cartographic.height 相差无几,注意:cartographic.height 可以为 0,也就是说,可以根据经纬度计算出高程。  
    var height = viewer.scene.globe.getHeight(cartographic);  
    var mapPosition = {
        x: lng,
        y: lat,
        z: height.height // height 的值为地形高度
    };
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);

获取模型表面的经纬度高程坐标(此方法借鉴于官方示例)

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);  
handler.setInputAction(function(evt) {  
    var scene = viewer.scene;  
    if (scene.mode !== Cesium.SceneMode.MORPHING) {  
        var pickedObject = scene.pick(evt.position);  
        if (scene.pickPositionSupported && Cesium.defined(pickedObject) && pickedObject.node) {  
            var cartesian = viewer.scene.pickPosition(evt.position);  
            if (Cesium.defined(cartesian)) {  
                var cartographic = Cesium.Cartographic.fromCartesian(cartesian);  
                var lng = Cesium.Math.toDegrees(cartographic.longitude);  
                var lat = Cesium.Math.toDegrees(cartographic.latitude);  
                var height = cartographic.height; // 模型高度  
                mapPosition = {
                    x: lng,
                    y: lat,
                    z: height
                } 
            }  
        }  
    }  
}, Cesium.ScreenSpaceEventType.LEFT_CLICK); 

如果您觉得这篇文章对您有帮助,欢迎给我的 github项目 点一个⭐ ο(=•ω<=)ρ⌒☆

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Apple_Coco

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值