百度地图getPoint赋值问题

        我们在js中调用百度地图的时候或许会遇到一个问题,设置的变量在myGeo.getPoint()这个方法中会出现取不到值的情况,究其原因,调用百度地图使用的是异步刷新,但是无论是在js文件里还是在html页面写的脚本,都不会停下来等待异步刷新结束再执行后面的代码,这样就会造成一个问题,在myGeo.getPoint()这个方法中获取到了经纬度信息,但是后面渲染到页面的时候会出现没有赋值的情况,解决方法也很简单,其一是把异步请求改为同步请求,但是百度地图不适用这种方法,那么久有了第二中方法,适用定时器来进行刷新,具体解决方案:

 <script type="text/javascript">
            //所有的功能代码都是从这里开始
            var map = new BMapGL.Map("myMap");
            map.centerAndZoom(地图中心点, 15);

            //声明四个变量,保存出发点和结束点的经纬度信息,直接使用两个变量保存点也可以
            var slng = 0, slat = 0, elng = 0, elat = 0;

            var myGeo = new BMapGL.Geocoder();
            myGeo.getPoint(
                startAddress,
                function (point) {
                    //在方法中给变量赋值
                    slng = point.lng;
                    slat = point.lat;
                    map.addOverlay(new BMapGL.Marker(point));
                    map.centerAndZoom(point, 15);
                },
                map
            );
            myGeo.getPoint(
                endAddress,
                function (point) {
                    elng = point.lng;
                    elat = point.lat;
                    map.addOverlay(new BMapGL.Marker(point));
                    map.centerAndZoom(point, 15);
                },
                map
            );

           
            //驾车导航
            function creatLine() {
                //在此处判断是否赋值,如果赋值成功,异步刷新回调,那么四个值均不为初始值,若有值没有赋值成功则使用定时器重复刷新此函数
                if (slng != 0 && slat != 0 && elng != 0 && elat != 0) {
                    //创建开始点和结束点,如果在前面不是获取经纬度,而是直接获取点,那么可以省略这一步
                    var start = new BMapGL.Point(slng, slat), end = new BMapGL.Point(elng, elat);
                    //渲染驾车路线
                    var driving = new BMapGL.DrivingRoute(map, {
                        renderOptions: {
                            map: map,
                            autoViewport: true
                        }
                    });
                    driving.search(start, end);
                } else {
                    //如果没有赋值,则重复刷新此函数代码,直到赋值成功完成渲染
                    setTimeout("creatLine()", 100);
                }
            }

            creatLine();
        </script>

 使用次方法可以解决百度地图调用时刷新参数取值问题。

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 百度地图getpoint是一个用于获取批量坐标的接口。在使用该接口前,我们需要准备好一份数据,这份数据包括待查询的地址或名称等信息。然后,通过调用getpoint接口,将数据传入接口中,接口会返回查询结果,并将结果中所有地址或名称的经纬度坐标信息一一对应。 使用getpoint接口还需要注意一些细节问题。首先,我们需要选择适当的查询方式。百度地图提供了多种查询方式,如通过地名或地址查询,通过经纬度范围查询等。在选择查询方式时,应根据实际需求和数据特点进行选择。其次,我们还需要注意接口参数的设置,例如查询方式、查询范围等。最后,我们可以对查询结果进行适当的处理和展示,如地图标注、统计分析等。 总之,百度地图getpoint是一个方便快捷的批量坐标查询工具,可以帮助我们高效地处理大量坐标信息,节省查询时间和成本。 ### 回答2: 百度地图API中有一个名为getPoint的方法可以帮助我们快速获取多条地理位置坐标信息。通过getPoint方法,我们可以传入一组地址信息,然后获取到这些地址对应的经纬度信息。 这个方法的使用非常简单,只需要在代码中引入百度地图Javascript API,然后创建Map对象。在Map对象中调用getPoint方法,传入参数,即可获取到所需的地址信息。 例如,我们可以编写以下代码来获取北京市朝阳区三里屯的地理坐标信息: var map = new BMap.Map("container"); var addressArr = ["北京市朝阳区三里屯SOHO"]; map.centerAndZoom("北京市", 15); var pointArr = []; for (var i = 0; i < addressArr.length; i++) { var address = addressArr[i]; var myGeo = new BMap.Geocoder(); myGeo.getPoint(address, function(point){ pointArr.push(point); console.log(pointArr); }); } 以上代码将创建一个地图对象,并定义一个包含北京市朝阳区三里屯商业区名字的地址数组。接着通过遍历地址数组,使用BMap.Geocoder的getPoint方法获取每个地址对应的地理位置坐标信息,并将这些坐标存储到一个数组中,最后在控制台打印输出。 通过这种方式,我们可以方便地获取多个地理位置的坐标信息,再分别在地图上显示出来。百度地图API的getPoint方法大大简化了我们获取地理信息的过程,可以有效提高地图应用的开发效率。 ### 回答3: 百度地图getpoint是一种用于获取地图上点坐标的API。该API允许用户通过在地图上单击或拖动鼠标来获取点坐标。同时,还可以使用批量获取的方法,通过传入坐标的数组来实现一次获取多个坐标点的功能。 具体来说,当我们需要获取多个坐标点时,可以将坐标点放入数组中,然后通过调用getpoint方法并传入包含坐标点数组的参数来实现批量获取。在返回的结果中,可以得到每个坐标点的经度和纬度信息,以及详细的位置描述信息。 除了普通的批量获取方法外,百度地图还提供了基于“矩形框”和“圆形范围”两种特定区域的批量坐标获取方式。用户可以根据需求选择不同的方法来获取所需要的坐标信息。 总之,百度地图getpoint提供了多种方式来获取批量坐标,极大地方便了用户在进行地图位置定位和数据分析等方面的工作,帮助用户更高效地完成地图相关的任务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值