繁体   English   中英

OpenLayers-地图拒绝最大化缩放

[英]OpenLayers - Map refusing to zoom to max extent

如果围绕某些OpenLayers代码进行更改,则副作用是Google Street基本图层不再显示明智的地图,而是缩小到3倍的世界视图。 我在api建议的代码中没有做任何工作。

相同的代码-但经过重新排列-过去可以正常使用(但不幸的是,它不允许更大的画面起作用)

我是这方面的新手,并且超出了我的舒适范围,因此对代码的健全性检查将不胜感激:

    function ProfileMap(mapName)
    {
        this.name = mapName;
        this.layers = [];

        // define Map options
        var mapoptions = {
                projection: mercator,
                units: "m",
                maxExtent: world
        };

        // define Base Layer
        var baselayer = new OpenLayers.Layer.Google(
                "Google Streets", 
                {numZoomLevels: 20, spehericalMercator: 2}
        );  


        this.init = function(mapdiv, keydiv)
        {
            var layerswitcher = new OpenLayers.Control.LayerSwitcher(
                    {div: document.getElementById(keydiv)}
            );      

            this.map = new OpenLayers.Map(mapdiv, mapoptions);
            this.map.addLayer(baselayer);
            this.map.setCenter(mapcenter);
            this.map.zoomToMaxExtent();

        };

        this.addMapLayer = function(layerName)
        {
            var layerid = this.layers.length;
            this.layers[layerid] = new OpenLayers.Layer.Markers(layerName);
            this.map.addLayer(this.layers[layerid]);
        }

    }


    // Map actually created by a call to this function
    function createMap(mapName, div, keydiv, mapLayers)
    {
        mapName = new ProfileMap(mapName);
        mapName.init(div, keydiv);
        for(var i=0; i < mapLayers.length; i++)
        {
            mapName.addMapLayer(mapLayers[i]);
        }

    }

可能一件事是您拼错了sphericalMercator 此外,它接受布尔值,而不是数字。

sphericalMercator: true

参考

更新#1:

请更改此:

var mapoptions = {
    projection: mercator,
    units: "m",
    maxExtent: world
};

为了这:

var mapoptions = {
    projection: new OpenLayers.Projection("EPSG:900913"),
    units: "m",
    maxExtent: world
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM