8

我正在尝试将 OpenLayers 设置为在缩放开始之前不显示矢量图层,并使其在缩放结束后重新出现。我已经像这样建立了缩放末端部分:

map = new OpenLayers.Map('map_element', { eventListeners: { "zoomend": mapEvent}});

function mapEvent(event) {
    if(event.type == "zoomend") {
        hide_vector_layer();
        }
}

但是我没有看到任何类型的事件监听器开始放大文档。有一个“movestart”,涵盖了移动、平移和缩放。不幸的是,我不能使用“movestart”,因为我不希望图层在平移过程中消失。你会认为会有一个“zoomstart”,因为有一个“zoomend”。

我之所以尝试这样做,是因为我不喜欢在使用谷歌地图作为基础层时矢量图层如何以不同的速度缩放。它看起来不对,看起来所有功能都不准确,即使它们在缩放完成后落在正确的位置。

有什么建议么?

4

5 回答 5

8

这是一个很容易将 'BeforeZoom' 事件添加到 OpenLayers 的方法。只需将下面的代码添加到您创建地图对象的位置。

map.zoomToProxy = map.zoomTo;
map.zoomTo =  function (zoom,xy){
    //Your Before Zoom Actions

    //If you want zoom to go through call
    map.zoomToProxy(zoom,xy); 
    //else do nothing and map wont zoom
};

这是如何工作的:

对于任何类型的缩放活动,OpenLayers API 最终都会调用名为 zoomTo 的函数。所以在覆盖它之前,我们将该函数复制到一个名为“zoomToProxy”的新函数中。我们覆盖它并添加我们的条件缩放逻辑。如果我们想要进行缩放,我们只需调用新的代理函数 :)

于 2013-06-26T16:17:14.353 回答
2

为此,您应该覆盖 OpenLayers.Map 的 moveTo 和 moveByPx 方法,以消除除缩放之外的任何操作的 movestart 事件触发。

于 2012-06-25T02:41:30.813 回答
2

我遇到了与 OP 相同的问题,我尝试使用 drnextgis 的解决方案来解决它。但不幸的是,它并没有完全起作用:: zoomChangedOpenLayers.Map.moveTo 中的属性true不仅在缩放级别发生变化时评估,而且在地图调整大小时评估。

我的地图是用户浏览器窗口的 100%,所以如果他们调整窗口大小,就会触发事件。这对我来说是不可取的,因为我只想在缩放级别实际发生变化时触发事件。我的解决方案是创建一个名为“zoomstart”的新事件,我将其插入到 OpenLayers.Map.moveTo 的顶部。这是代码:

var getZoom = this.getZoom();
if ( !!getZoom && !!zoom && this.isValidZoomLevel(zoom) && getZoom != zoom )
    this.events.triggerEvent("zoomstart", zoom);

此代码会将新的缩放级别传递给注册到的事件侦听器zoomstart,在我的情况下,我确定地图的限制范围并根据新的缩放级别执行其他操作。

愿你们平安。

于 2013-02-25T23:45:18.297 回答
1

“movestart”处理“zoomstart”。要检测 zoomstart 是否启动,请尝试:

 map.events.register("movestart",map, function(e) {
        if(e.zoomChanged)
        {
        //zoom start code here
        }

    });
于 2014-02-19T04:14:49.737 回答
0

“Shaunak”的解决方案对我来说效果很好。我想将缩放限制在 11 以下,因此将他的代码编辑为

if (zoom > 11) {
    map.zoomToProxy(zoom, xy);
}
于 2013-09-18T07:02:00.870 回答