Cesium屏幕中心坐标和相机位置坐标计算

1.获取当前屏幕中心点的位置

javascript 复制代码
    getCenterPosition() {
        let centerResult = viewer.camera.pickEllipsoid(
            new Cesium.Cartesian2(
                viewer.canvas.clientWidth / 2,
                viewer.canvas.clientHeight / 2,
            ),
        )
        centerPoint = centerResult;
        let curPosition = Cesium.Ellipsoid.WGS84.cartesianToCartographic(centerResult);
        let curLongitude = (curPosition.longitude * 180) / Math.PI;
        let curLatitude = (curPosition.latitude * 180) / Math.PI;
        return {
            lon: curLongitude,
            lat: curLatitude,
        }
        // }
    }

2.获取当前相机的位置

javascript 复制代码
 getCameraPosition() {
        var position = viewer.scene.camera.positionCartographic;
        // 弧度转经纬度
        var longitude = Cesium.Math.toDegrees(position.longitude);
        var latitude = Cesium.Math.toDegrees(position.latitude);
        var height = position.height;
        return { lng: longitude, lat: latitude, h: height }
    }

3.绕非固定屏幕中心点旋转

moveRotation方法参数中第一个参数step是移动步长,第二个参数i是判断是否是俯仰角还是航向角进行绕中心点进行翻滚,entity可以另外分离出来做一个方法,这样避免每次调用moveRotation方法都生成一个entity覆盖物。

javascript 复制代码
  moveRotation(step, i = 0) {
        // 添加实体
        let a = this.getCenterPosition();
        let b = this.getCameraPosition();
        entity = viewer.entities.add({
            position: new Cesium.Cartesian3.fromDegrees(a.lon, a.lat, 0),
            point: {
                pixelSize: 0,
                // show: false
            }
        });
        let clickPosition1 = Cesium.Cartesian3.fromDegrees(a.lon, a.lat, 0);
        let clickPosition2 = Cesium.Cartesian3.fromDegrees(b.lng, b.lat, b.h);
        // 计算两个点之间的距离
        let distancetemp = Cesium.Cartesian3.distance(clickPosition1, clickPosition2);
        // 距离远一些就将移动角度调整大一些
        if (i && distancetemp > 20000) {
            heading += 3 * step;
        } else if (i) {
            heading += step;
        } else if (!i && distancetemp > 20000) {
            pitch += 3 * step;
        } else if (!i) {
            pitch += step;
        }
       let offset = new Cesium.HeadingPitchRange(
            heading,
            pitch,
            distancetemp  // 相机距离地球球心的距离
        );
        viewer.zoomTo(entity, offset);
    }

4.相机位置在原地据法向量升起和下降

该方法的参数distance接受正负数,对应上升和下降

javascript 复制代码
   moveForward(distance) {
        var camera = viewer.camera;
        var direction = camera.direction;
        //获得此位置默认的向上方向
        var up = Cesium.Cartesian3.normalize(camera.position, new Cesium.Cartesian3());
        var right = Cesium.Cartesian3.cross(direction, up, new Cesium.Cartesian3());
        direction = Cesium.Cartesian3.cross(up, right, new Cesium.Cartesian3());
        direction = Cesium.Cartesian3.normalize(direction, direction);
        direction = Cesium.Cartesian3.multiplyByScalar(direction, distance, direction);
        camera.position = Cesium.Cartesian3.add(camera.position, direction, camera.position);
    }
相关推荐
晓得迷路了几秒前
栗子前端技术周刊第 88 期 - Apache ECharts 6.0 beta、Deno 2.4、Astro 5.11...
前端·javascript·echarts
江城开朗的豌豆6 分钟前
在写vue公用组件的时候,怎么提高可配置性
前端·javascript·vue.js
江城开朗的豌豆6 分钟前
Vue路由跳转的N种姿势,总有一种适合你!
前端·javascript·vue.js
江城开朗的豌豆7 分钟前
Vue路由玩法大揭秘:三种路由模式你Pick谁?
前端·javascript·vue.js
江城开朗的豌豆7 分钟前
Vue路由守卫全攻略:给页面访问装上'安检门'
前端·javascript·vue.js
小磊哥er14 分钟前
【前端工程化】前端组件模版构建那些事
前端
前端 贾公子15 分钟前
monorepo + Turborepo --- 开发应用程序
java·前端·javascript
江城开朗的豌豆20 分钟前
Vue路由传参避坑指南:params和query的那些猫腻
前端·javascript·vue.js
十里青山28 分钟前
超好用的vue图片预览插件更新啦,hevue-img-preview 7.0.0版本正式发布,支持vue2/vue3/移动/pc,增加缩略图、下载、自定义样式等
前端·javascript·vue.js
lichenyang45337 分钟前
css模块化以及rem布局
前端·javascript·css