打开和关闭 MouseWheelZoom

Jam*_*rne 3 openlayers-3

如何切换鼠标滚轮缩放功能?

我知道您可以在创建地图时设置 mousewheelzoom 默认值:

    interactions: ol.interaction.defaults({
        mouseWheelZoom: false
    }),
Run Code Online (Sandbox Code Playgroud)

但是,一旦创建了地图,我该如何更改它,即当用户单击地图时,我想运行一个例程来重新打开鼠标滚轮缩放?

我知道这在 Openlayers2 中很棘手 - 你必须循环控制:

function PMA_Mapping_Enable_Mouse_Wheel_Zoom(map) {
//Need to go through all controls - don't know why!
controls = map.getControlsByClass('OpenLayers.Control.Navigation');
for (var i = 0; i < controls.length; ++i)
    controls[i].enableZoomWheel();};
Run Code Online (Sandbox Code Playgroud)

不知道这是否有帮助,但我认为我应该包括它。

有谁知道如何在 openlayers 3 中实现这一目标?

pav*_*los 5

Mouseweel 是一种交互而不是控件。所以,你总是可以使用

interaction.setActive(true),interaction.setActive(false)切换交互。

像这样开始你的地图初始化:

......interactions: ol.interaction.defaults({ mouseWheelZoom: false }), .......

然后,一旦您的地图准备就绪,就可以像这样创建 mouseWheel 交互:

var mouseWheelInt = new ol.interaction.MouseWheelZoom(); map.addInteraction(mouseWheelInt)

然后切换它:

mouseWheelInt.setActive(!mouseWheelInt.getActive())