3

当用户在此处单击此页面上的地图时,我正在使用模式弹出窗口,这会显示一个带有方向的更大地图。

然而,地图并没有填满整个空间,我不知道为什么。当我右键单击它以签入 chrome 检查器时,它会使地图​​填充模态。

请原谅所有代码,但我认为最好将其全部包含在内:

       <div class="map clearfix">
            <div class="bg left-contact">
            <% if len(""&rsAdvert("ContactPostcode"))>0 then %>
                      <a href="#myModal" role="button" data-toggle="modal">
<div class="small-map" style="width:100%;height:130px;background:url(http://maps.google.com/maps/api/staticmap?center=<%=server.URLEncode(""&rsAdvert("ContactPostcode"))%>&zoom=14&size=250x250&maptype=roadmap&markers=color:ORANGE|label:A|<%=server.URLEncode(""&rsAdvert("ContactPostcode"))%>&sensor=false) center no-repeat;"></div></a>
                      <div class="expand"></div>
    <!-- Modal -->
    <div id="myModal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
        <h3 id="myModalLabel">Modal header</h3>
      </div>
      <div class="modal-body">
        <p><div id='map-canvas'></div></p>
      </div>
      <div class="modal-footer">
        <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
        <button class="btn btn-primary">Save changes</button>
      </div>
    </div>
        <script src="http://code.jquery.com/jquery.js"></script>
        <script src="/js/bootstrap/js/bootstrap.min.js"></script>
               <% end if %> 
            </div>
        </div>

     <script src="http://maps.googleapis.com/maps/api/js?q=London&key=AIzaSyBaPEDyFbbnWjtvT8W3UBOM34Y7g6vK69A&sensor=false"></script>
    <script>
        var map;
        function initialize() {
          var mapOptions = {
            zoom: 15,
            center: new google.maps.LatLng(-34.397, 150.644),
            mapTypeId: google.maps.MapTypeId.ROADMAP
          };
          var geolocate = function(address, callback) {
                $.ajax({
                        url: "http://maps.googleapis.com/maps/api/geocode/json",
                        data: {
                            "sensor": true,
                            "address": address
                        },
                        dataType: "json",
                        success: function(d) {
                            if (d.status == "ZERO_RESULTS") callback(false);
                            if (d.results && d.results[0] && d.results[0].geometry) {
                                callback({
                                    "ne": d.results[0].geometry.bounds.northeast,
                                    "sw": d.results[0].geometry.bounds.southwest,
                                    "center": d.results[0].geometry.location
                                });
                            }
                            else callback(false);
                        }
                    });
          };
          map = new google.maps.Map(document.getElementById('map-canvas'),
              mapOptions);
          geolocate("<%=server.URLEncode(""&rs("ca_postcode"))%>", function(c) {
                map.setCenter(new google.maps.LatLng(c.center.lat, c.center.lng));
         });
        }
        google.maps.event.addDomListener(window, 'load', initialize);
    </script>

谢谢。

4

5 回答 5

4

为了完整性:如果您使用的是Bootstrap 模式窗口,则需要使用shown.bs.modal事件代替shown事件。

这里的代码:

  $("#modalWindowId").on("shown.bs.modal", function(e) {
    google.maps.event.trigger(map, "resize");
    map.setCenter(markerLatLng); // Set here center map coordinates
  });

看看这里了解更多信息: http ://coderpills.wordpress.com/2014/06/02/showing-google-map-inside-a-bootstrap-modal-window/

于 2014-06-02T13:39:26.673 回答
3

您可以在模式启动后在地图上触发一个resize事件,这将导致它调整大小以适应包含的尺寸div。从文档中:

当 div 改变大小时,开发者应该在地图上触发这个事件

// Add this at the bottom of the script which defines your map
// It will trigger the resize event on the map after the modal has launched
$('#myModal').on('shown', function () {
  google.maps.event.trigger(map, 'resize');
})

我认为当您启动开发工具时,该window.onResize事件会导致该resize事件在地图上被触发。您可以通过在单击模态之前从浏览器窗口中分离开发工具来证明这一点。

于 2013-05-13T23:57:17.340 回答
0

尝试使用这个

填充:0;

CSS:

.modal-body {
max-height: 400px;
overflow-y: auto;
padding: 0;
position: relative;
     }
于 2013-05-14T00:09:14.087 回答
0

谢谢你们的答案。只是为了帮助其他可能遇到此问题的人,除了由于地图处于模式中而必须调整大小之外,我还必须重置中心。

需要在initialize函数中添加以下代码。

    $('#show_map').on('shown', function () {
        google.maps.event.trigger(map, "resize");
        map.setCenter(myLatlng);
    });
于 2013-09-04T15:02:35.810 回答
0
$('#Map_Modal_ID').on('shown.bs.modal', function () {
    initialize();
});
于 2015-05-06T09:24:04.093 回答