2

我已经为 Here Maps Javascript API: 3.1 实现了新版本,我想禁用鼠标滚轮,但仅在滚动地图本身时,而不是所有页面。

请参阅以下示例:https ://jsfiddle.net/ms57x34z/ 。当我在地图上方时,我仍然希望能够向下滚动页面,这样我就可以到达页脚内容。

                  
/**
 * Moves the map to display over Berlin
 *
 * @param  {H.Map} map      A HERE Map instance within the application
 */
function moveMapToBerlin(map){
  map.setCenter({lat:52.5159, lng:13.3777});
  map.setZoom(14);
}

/**
 * Boilerplate map initialization code starts below:
 */

//Step 1: initialize communication with the platform
// In your own code, replace variable window.apikey with your own apikey
var platform = new H.service.Platform({
  apikey: 'somevalue'
});

var defaultLayers = platform.createDefaultLayers();

//Step 2: initialize a map - this map is centered over Europe
var map = new H.Map(document.getElementById('map'),
  defaultLayers.vector.normal.map,{
  center: {lat:50, lng:5},
  zoom: 4,
  pixelRatio: window.devicePixelRatio || 1
});
// add a resize listener to make sure that the map occupies the whole container
window.addEventListener('resize', () => map.getViewPort().resize());

//Step 3: make the map interactive
// MapEvents enables the event system
// Behavior implements default interactions for pan/zoom (also on mobile touch environments)
var behavior = new H.mapevents.Behavior(new H.mapevents.MapEvents(map));
console.log(behavior);


behavior.disable(H.mapevents.Behavior.WHEELZOOM);

// Create the default UI components
var ui = H.ui.UI.createDefault(map, defaultLayers);

// Now use the map as required...
window.onload = function () {
  moveMapToBerlin(map);
}
#map {
  width: 95%;
  height: 450px;
  background: grey;
}

#panel {
  width: 100%;
  height: 400px;
}
<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=yes">
    <meta http-equiv="Content-type" content="text/html;charset=UTF-8">
    <title>Map at a specified location</title>
    <link rel="stylesheet" type="text/css" href="https://js.api.here.com/v3/3.1/mapsjs-ui.css" />
    <link rel="stylesheet" type="text/css" href="css/app.css" />
    <script type="text/javascript" src='../test-credentials.js'></script>    
    <script type="text/javascript" src="https://js.api.here.com/v3/3.1/mapsjs-core.js"></script>
    <script type="text/javascript" src="https://js.api.here.com/v3/3.1/mapsjs-service.js"></script>
    <script type="text/javascript" src="https://js.api.here.com/v3/3.1/mapsjs-ui.js"></script>
    <script type="text/javascript" src="https://js.api.here.com/v3/3.1/mapsjs-mapevents.js"></script>
    <script type="text/javascript" >window.ENV_VARIABLE = 'https://developer.here.com'</script>
    <script src='https://developer.here.com/javascript/src/iframeheight.js'></script>
  </head>
  <body id="markers-on-the-map">
    <div id="map" style="width: 500px; height: 800px"></div>
    <script type="text/javascript" src='js/app.js'></script>
    <div>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
        Footer content<br/><br/>
    </div>
  </body>
</html>

这种情况有解决办法吗?

4

2 回答 2

1

在等待 API 更新期间,我们对 HERE 地图滚动问题实施了临时修复。

我们将一个不可见元素添加到添加地图的同一个容器中,并将其定位,使其完全覆盖地图。

<div class="map-container">
    <div id="map-fixer" style="position: absolute; background-color: transparent; width: 100%; height: 100%; z-index: 1000; display: none;"></div>
</div>

然后,当我们检测到鼠标滚轮事件时,我们会显示这一点。

(function () {
    var scrolling = false;
    var scrollEnd = null;

    function heremapScrollEnd() {
        scrolling = false;
        window.clearTimeout(scrollEnd);
        document.getElementById('map-fixer').style.display = 'none';
    }

    window.onwheel = function() {
        if (scrolling) {
            window.clearTimeout(scrollEnd);
            window.setTimeout(heremapScrollEnd, 200);
            return;
        }
        scrolling = true;
        document.getElementById('map-fixer').style.display = 'block';
        window.setTimeout(heremapScrollEnd, 1000);
    }
})();

这意味着鼠标滚轮被我们的“备用元素”捕获并且滚动正常发生。滚动完成后,不可见元素会被移除,这意味着其他地图交互仍然有效。

我们确实尝试过清除 HERE Maps 添加的 wheel 事件,但无法获得可靠的句柄(如果您没有相同的函数句柄,则删除事件侦听器会很棘手)。我们还尝试将鼠标增量应用于滚动位置,但这不适用于不同的鼠标速度和方向。最后的实验是固定覆盖,但这会阻止地图的其他功能可访问(单击、拖动、缩放)。这就是导致我们使用这种方法的原因。

于 2021-03-08T16:05:41.230 回答
0

对,定义

行为.禁用(H.mapevents.Behavior.Feature.WHEEL_ZOOM)

应该允许滚动整个页面,但目前此功能尚未实现。

此功能(整个页面的滚动)稍后将在 HERE JS API for map 中提供。

于 2020-10-02T13:12:05.590 回答