8

我正在写一个页面,您可以在其中查看有关区域和地图的详细信息。详细信息在一个选项卡上,地图在另一个选项卡上。HTML 的相关部分如下,类来自Bootstrap

<div class="col-xs-8">
    <ul class="nav nav-tabs">
        <li class="active"><a href="#tab-details" data-toggle="tab">Details</a></li>
        <li><a href="#tab-map" data-toggle="tab">Map</a></li>
    </ul>
    <div class="tab-content">
        <div id="tab-details" class="tab-pane fade in active"></div>
        <div id="tab-map" class="tab-pane fade">
            <div id="map-container" class="map"></div>
        </div>
    </div>
</div>

切片图层来自 OSM,矢量图层通过提供 KML 文件的 URL 加载。它使用OpenLayers 3.0.0执行此操作,如下所示:

function ShowMap() {
    var area = $('#AreaCode').val();
    $('#map-container').empty();
    if (area != null && area != '') {
        var kmlUrl = '/kml?code=' + area;
        var tile = new ol.layer.Tile({ source: new ol.source.OSM() });
        var vectorSource = new ol.source.KML({ url: kmlUrl, projection: 'EPSG:3857' });
        var vector = new ol.layer.Vector({ source: vectorSource });
        vector.setOpacity(.3);
        var map = new ol.Map({
            target: 'map-container',
            layers: [tile, vector],
            view: new ol.View({
                center: [0, 0],
                zoom: 2
            })
        });

        vector.addEventListener("change", function(event) {
            map.getView().fitExtent(vectorSource.getExtent(), map.getSize());
        });
    }
}

$('#tab-map-link').on('shown.bs.tab', function(event) {
    ShowMap();
});

这会在单击地图选项卡时呈现地图,从而导致小的延迟。即使未选择选项卡,有没有办法加载它?如果我尝试这样做并且在选择地图选项卡时不重绘,那么当我切换到地图选项卡时画布是空白的,并且只显示放大和缩小按钮。

有没有办法在不可见的元素中渲染地图?

4

2 回答 2

10

您可以在隐藏的容器中初始化地图,然后在激活标签时,可以在地图上调用更新

map.updateSize()
于 2014-09-26T12:38:02.537 回答
1

在我的情况下,解决方案是使用超时等待 div 显示。

setTimeout(function() {
    map.updateSize();
}, 100);
于 2020-03-23T16:07:28.357 回答