如何解决Here Maps 3.1使用Here Maps的鼠标滚轮事件
我已经为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>
有没有针对这种情况的解决方案?
解决方法
没错,
behavior.disable(H.mapevents.Behavior.Feature.WHEEL_ZOOM)
本应允许滚动整个页面,但当前尚未实现此功能。
此功能(整个页面的滚动)稍后将在HERE JS API中提供。
,我们已经实现了 temporary fix for HERE Maps scroll issues,同时等待 API 更新。
我们将一个不可见元素添加到我们添加地图的同一个容器中,并将其定位,使其完全覆盖地图。
<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 添加的滚轮事件,但无法获得可靠的句柄(如果您没有相同的函数句柄,删除事件侦听器会很棘手)。我们还尝试将鼠标增量应用于滚动位置,但这不适用于不同的鼠标速度和方向。最后的实验是一个固定的叠加层,但这会阻止访问地图的其他功能(单击、拖动、缩放)。这就是导致我们使用这种方法的原因。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。