如何在谷歌地图中将信息窗口显示在折线的正上方?

3

问题在于我从数据库中获取了纬度和经度信息,并在谷歌地图上绘制折线和信息窗口,但是它与标记一起工作得很好。然而,即使我已将其位置设置为底部,信息窗口仍会出现在谷歌地图的顶部。

我已使用以下代码:

 <script type="text/javascript">


 function initialize()
        {
          var map;

           var markers = JSON.parse('<%=ConvertDataTabletoString() %>');
     var infoWindow = new google.maps.InfoWindow({maxWidth:200,minWidth:200});
           var marker;

           var x=new google.maps.LatLng(16.697000,74.244000);
       var stavanger=new google.maps.LatLng(markers[0].lat1, markers[0].lng1);

         var london=new google.maps.LatLng(markers[0].lat, markers[0].lng);
           var j=0;

           var i=0;
           var points=new Array();
           var points2=new Array();

           var mapProp = {
           center:new google.maps.LatLng(markers[0].lat, markers[0].lng),
           zoom:14,
           mapTypeId:google.maps.MapTypeId.ROADMAP

            }; 
   var map=new google.maps.Map(document.getElementById("map_canvas"),mapProp);

             google.maps.event.addListener(map, "click", function(event)
        {

                var marker = new google.maps.Marker({
                position: event.latLng, 
                 animation: google.maps.Animation.DROP,
                map: map

                });


              document.getElementById("txttolat").value = event.latLng.lat();
             document.getElementById("txttolong").value = event.latLng.lng();

               var pt=event.latLng.lat();
             points[j]=event.latLng.lat();

             points2[j]=event.latLng.lng();
             j=j+1;

              document.getElementById("txtlat").value = points[0];
             document.getElementById("txtlong").value = points2[0];
             //            });

              });

             for (i = 0; i < markers.length; i++) {
             var data = markers[i]

    var stavanger2=new google.maps.LatLng(markers[i].lat1, markers[i].lng1);

         var london2=new google.maps.LatLng(markers[i].lat, markers[i].lng);

              var myTrip=[stavanger2,london2];
               var flightPath=new google.maps.Polyline({




                path:myTrip,
            strokeColor:"#0000FF",
             strokeOpacity:0.8,
             strokeWeight:10,
               map: map,
               title: data.title
                    });
                  // }
                  (function(flightPath, data) {

           google.maps.event.addListener(flightPath, 'click', function(e) {
                 // alert('you clicked polyline');

               infoWindow.setContent(data.description);

                 infoWindow.open(map,flightPath);
                 infoWindow.setPosition(e.latLng);
                 document.getElementById("txtname").value = data.title;

                  document.getElementById("txtlat").value = e.latLng.lat();
                  document.getElementById("txtlong").value = e.latLng.lng();
                     });

                      })(flightPath, data);


                       }
                       }



               google.maps.event.addDomListener(window, 'load', initialize);
                    </script>
1个回答

3
您需要更改flightpathclick事件监听器。
根据Google API参考InfoWindow类,方法open()定义如下: open(map?:Map|StreetViewPanorama, anchor?:MVCObject) 打开此信息窗口在给定的地图上。可选地,信息窗口可以与一个锚相关联。在核心API中,唯一的锚是Marker类。然而,锚可以是任何公开LatLng位置属性以及可选的用于计算像素偏移量(请参见InfoWindowOptions)的Point anchorPoint属性的MVCObject。anchorPoint是从锚点位置到信息窗口顶端的偏移量。
您使用了没有提供位置属性的flightPath(Polyline)作为锚。
因此,首先获取单击位置,然后在地图上打开信息窗口:
infoWindow.setPosition(e.latLng);
infoWindow.open(map);

// infoWindow.open(map,flightPath);
// infoWindow.setPosition(e.latLng);

请查看JSBin的示例。注意:我不得不伪造JSON.parse()方法来获取一些数据。


嘿,谢谢,但它仍然显示相同的结果,而且关闭按钮没有显示在InfoWindow上,我真的不知道该怎么办? - Priyanka
嘿,非常感谢你抽出时间为我提供示例,真的很感激。谢谢 :) - Priyanka

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接