Cesium 使用graphhopper实现路径规划

var Graphhopperip = 'http://127.0.0.1:9090';//路径规划


 //界面按钮绑定事件
        function addUIListen() {
            document.getElementById("startPosButton").onclick = startPosButtonClick;
            document.getElementById("endPosButton").onclick = endPostButtonClick;
            document.getElementById("beginButton").onclick = startButtonClick;

        }
        addUIListen();
        var handler;
        var mouseStart = undefined;//鼠标起点
        var mouseEnd = undefined;//鼠标终点
        //设置起始位置坐标
        function startPosButtonClick() {

            console.log("设置起始位置坐标");
            //定义canvas屏幕点击事件
            handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
            //注册鼠标事件,event参数是点击的地方是在哪里
            handler.setInputAction(function (movement) {
                // debugger
                //定义一个屏幕点击的事件,pickPosition封装的是获取点击的位置的坐标
                var ray = viewer.camera.getPickRay(movement.position);
                var position = viewer.scene.globe.pick(ray, viewer.scene);
                //输出之后我们发现坐标信息都是大数目,因为cesium定义的球体坐标都是笛卡尔坐标,所以我们需要转换笛卡尔坐标
                console.log("笛卡尔:" + position);
                //将笛卡尔坐标转化为弧度坐标
                var cartographic = Cesium.Cartographic.fromCartesian(position);
                console.log("弧度:" + cartographic);
                //将弧度坐标转换为经纬度坐标(先转弧度再转经纬度简单一点,直接转换的方法也有,不过推荐用这种)
                var longitude = Cesium.Math.toDegrees(cartographic.longitude); //经度
                var latitude = Cesium.Math.toDegrees(cartographic.latitude); //纬度
                var height = cartographic.height; //高度
                console.log("经纬度:" + longitude, latitude, height);

                console.log("经度:" + longitude + "纬度:" + latitude + "高度:" + height);

                let CartographicCenter = new Cesium.Cartographic(Cesium.Math.toRadians(longitude), Cesium.Math.toRadians(latitude), height);

                setStartPointData(longitude, latitude, height);

                var pos = {
                    longitude: longitude,
                    latitude: latitude,
                    height: height
                }
                var startp = cm.CreatePoint(pos, "pathstartpoint", "../img/icon.png", "路径起点");


            }, Cesium.ScreenSpaceEventType.LEFT_CLICK);

        }

        //设置终点位置坐标
        function endPostButtonClick() {

            console.log("设置终点位置坐标");
            //定义canv
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值