作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个自动打开的信息窗口,我想将其置于我的 Google map 的中心。
我不想以标记本身为中心,而是以标记加上信息窗口为中心,因为如果单击打开而不是默认打开框,它会自动执行。
这是我的代码:
<script>
function initMap() {
var occ = {lat: 45.5280879, lng: -122.6630186};
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 14,
draggable: false,
scrollwheel: false,
center: occ
});
var contentString = '<div id="content" style="font-family: Poppins, sans-serif; padding: 1em;">'+
'<div id="siteNotice">'+
'</div>'+
'<h4 style="margin-bottom: .125em;">The Oregon Convention Center</h4>'+
'<p>777 NE Martin Luther King Jr Blvd<br>'+
'Portland, OR 97232<br>'+
'<a href="https://www.google.com/maps/dir//Oregon+Convention+Center,+777+NE+Martin+Luther+King+Jr+Blvd,+Portland,+OR+97232,+United+States/@45.5280879,-122.6630186,15z/data=!4m12!1m3!3m2!1s0x0:0x610cf37babf5b9df!2sOregon+Convention+Center!4m7!1m0!1m5!1m1!1s0x5495a0adc5ff1af5:0x610cf37babf5b9df!2m2!1d-122.6630186!2d45.5280879" target="_blank">Get directions</a></p>'+
'</div>';
var infowindow = new google.maps.InfoWindow({
content: contentString,
pixelOffset: new google.maps.Size(0, 15),
});
var marker = new google.maps.Marker({
position: occ,
map: map,
title: 'The Oregon Convention Center',
});
infowindow.open(map, marker);
google.maps.event.addDomListener(window, "resize", function() {
var center = map.getCenter();
google.maps.event.trigger(map, "resize");
map.setCenter(center);
});
}
</script>
fiddle :http://jsfiddle.net/kz1hnec0/
我该怎么做?
最佳答案
基于这个答案:https://stackoverflow.com/a/10722973/1023562
创建一个将您的中心偏移一些像素的函数:
function map_recenter(map,latlng,offsetx,offsety) {
var point1 = map.getProjection().fromLatLngToPoint(
(latlng instanceof google.maps.LatLng) ? latlng : map.getCenter()
);
var point2 = new google.maps.Point(
( (typeof(offsetx) == 'number' ? offsetx : 0) / Math.pow(2, map.getZoom()) ) || 0,
( (typeof(offsety) == 'number' ? offsety : 0) / Math.pow(2, map.getZoom()) ) || 0
);
map.setCenter(map.getProjection().fromPointToLatLng(new google.maps.Point(
point1.x - point2.x,
point1.y + point2.y
)));
}
使用 projection_changed
事件调用此函数(因为在此事件发生之前 map.getProjection()
不可用):
google.maps.event.addListenerOnce(map,"projection_changed", function() {
map_recenter(map, occ, 0, -100);
});
工作 fiddle :http://jsfiddle.net/kz1hnec0/4/
注意:
我已将 Y 偏移设置为 -100。如果您知道您的信息窗口有多高(在本例中为 155px),那么您可以更精确地传递此值 - 我想这将类似于 (infoWindow.height + infoWindow.pixelOffset/2)
。
关于google-maps - 谷歌地图 : Center Auto-Opening infoWindow,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32001251/
leaflet:一个开源并且对移动端友好的交互式地图 JavaScript 库 中文文档: https://leafletjs.cn/reference.html 官网(英文): ht
我是一名优秀的程序员,十分优秀!