Маркер API Google Maps v3 с меткой
Я новичок в JS и Google API, и я пытаюсь сделать несколько маркеров с меткой.
Из небольших фрагментов, на которые я смотрел, не было простого способа привязать ярлык к маркеру в Google Maps API версии 3. Между поисками Google и stackoverflow все использовали процедуру окольного обхода, которая включала создание или редактирование класса метки.
Я просто хочу понять, как добавить ярлык к каждому маркеру простым способом, так как я только начинаю изучать JS/Google API v3.
Спасибо
ИЗМЕНИТЬ № 3:
Хорошо, я наконец понял, что было неправильно, и правильно реализовал несколько маркеров с помощью меток Lilina. По-видимому, мы оба определили карту var по-разному, и это само по себе делает наши коды неспособными хорошо синхронизировать.
У меня есть дополнительный вопрос, когда я могу использовать метки для каждого маркера.
Я хочу иметь возможность скрывать маркеры и их метки на основе уровня масштабирования, на котором находится пользователь.
API Карт Google v3 - Различные маркеры/метки на разных уровнях масштабирования
Ответы
Ответ 1
Я не могу гарантировать, что это самый простой, но мне нравится MarkerWithLabel. Как показано в базовом примере, стили CSS определяют внешний вид ярлыка и параметры в JavaScript определяют содержимое и размещение.
.labels {
color: red;
background-color: white;
font-family: "Lucida Grande", "Arial", sans-serif;
font-size: 10px;
font-weight: bold;
text-align: center;
width: 60px;
border: 2px solid black;
white-space: nowrap;
}
JavaScript:
var marker = new MarkerWithLabel({
position: homeLatLng,
draggable: true,
map: map,
labelContent: "$425K",
labelAnchor: new google.maps.Point(22, 0),
labelClass: "labels", // the CSS class for the label
labelStyle: {opacity: 0.75}
});
Единственная часть, которая может ввести в заблуждение, - это labelAnchor. По умолчанию верхний левый угол этикетки будет располагаться до конечной точки маркера маркера. Установка значения labelAnchor x до половины ширины, определенной в свойстве ширины CSS, будет центрировать метку. Вы можете сделать поплавок этикетки над маркером канцелярской кнопкой с узловой точкой, как new google.maps.Point(22, 50)
.
Если доступ к ссылкам выше заблокирован, я скопировал и вставил упакованный источник MarkerWithLabel в этот JSFiddle demo. Я надеюсь, что JSFiddle разрешен в Китае: |
Ответ 2
Чтобы добавить ярлык к карте, вам нужно создать пользовательский оверлей. Образец в http://blog.mridey.com/2009/09/label-overlay-example-for-google-maps.html использует пользовательский класс Layer
, который наследует от OverlayView
(который наследует от MVCObject
) от API Карт Google. У него есть исправленная версия (добавлена поддержка видимости, zIndex и событие click), которые можно найти здесь: http://blog.mridey.com/2011/05/label-overlay-example-for-google-maps.html
Следующий код берется непосредственно из блога Marc Ridey (пересмотренная ссылка выше).
Класс уровня
// Define the overlay, derived from google.maps.OverlayView
function Label(opt_options) {
// Initialization
this.setValues(opt_options);
// Label specific
var span = this.span_ = document.createElement('span');
span.style.cssText = 'position: relative; left: -50%; top: -8px; ' +
'white-space: nowrap; border: 1px solid blue; ' +
'padding: 2px; background-color: white';
var div = this.div_ = document.createElement('div');
div.appendChild(span);
div.style.cssText = 'position: absolute; display: none';
};
Label.prototype = new google.maps.OverlayView;
// Implement onAdd
Label.prototype.onAdd = function() {
var pane = this.getPanes().overlayImage;
pane.appendChild(this.div_);
// Ensures the label is redrawn if the text or position is changed.
var me = this;
this.listeners_ = [
google.maps.event.addListener(this, 'position_changed', function() { me.draw(); }),
google.maps.event.addListener(this, 'visible_changed', function() { me.draw(); }),
google.maps.event.addListener(this, 'clickable_changed', function() { me.draw(); }),
google.maps.event.addListener(this, 'text_changed', function() { me.draw(); }),
google.maps.event.addListener(this, 'zindex_changed', function() { me.draw(); }),
google.maps.event.addDomListener(this.div_, 'click', function() {
if (me.get('clickable')) {
google.maps.event.trigger(me, 'click');
}
})
];
};
// Implement onRemove
Label.prototype.onRemove = function() {
this.div_.parentNode.removeChild(this.div_);
// Label is removed from the map, stop updating its position/text.
for (var i = 0, I = this.listeners_.length; i < I; ++i) {
google.maps.event.removeListener(this.listeners_[i]);
}
};
// Implement draw
Label.prototype.draw = function() {
var projection = this.getProjection();
var position = projection.fromLatLngToDivPixel(this.get('position'));
var div = this.div_;
div.style.left = position.x + 'px';
div.style.top = position.y + 'px';
div.style.display = 'block';
this.span_.innerHTML = this.get('text').toString();
};
Использование
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>
Label Overlay Example
</title>
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript" src="label.js"></script>
<script type="text/javascript">
var marker;
function initialize() {
var latLng = new google.maps.LatLng(40, -100);
var map = new google.maps.Map(document.getElementById('map_canvas'), {
zoom: 5,
center: latLng,
mapTypeId: google.maps.MapTypeId.ROADMAP
});
marker = new google.maps.Marker({
position: latLng,
draggable: true,
zIndex: 1,
map: map,
optimized: false
});
var label = new Label({
map: map
});
label.bindTo('position', marker);
label.bindTo('text', marker, 'position');
label.bindTo('visible', marker);
label.bindTo('clickable', marker);
label.bindTo('zIndex', marker);
google.maps.event.addListener(marker, 'click', function() { alert('Marker has been clicked'); })
google.maps.event.addListener(label, 'click', function() { alert('Label has been clicked'); })
}
function showHideMarker() {
marker.setVisible(!marker.getVisible());
}
function pinUnpinMarker() {
var draggable = marker.getDraggable();
marker.setDraggable(!draggable);
marker.setClickable(!draggable);
}
</script>
</head>
<body onload="initialize()">
<div id="map_canvas" style="height: 200px; width: 200px"></div>
<button type="button" onclick="showHideMarker();">Show/Hide Marker</button>
<button type="button" onclick="pinUnpinMarker();">Pin/Unpin Marker</button>
</body>
</html>
Ответ 3
вышеупомянутые решения не будут работать на ipad-2
В последнее время у меня была проблема сбоя браузера сафари при построении маркеров, даже если количество маркеров меньше. Первоначально я использовал маркер с меткой (markerwithlabel.js)
для построения маркера, когда я использую собственный маркер google, он работал нормально даже с большим количеством маркеров, но я хочу настроить маркеры, поэтому я ссылаюсь на вышеупомянутое решение, данное jonathan, но все же проблема с сбоем не решена после выполнения множества исследований я узнал о http://nickjohnson.com/b/google-maps-v3-how-to-quickly-add-many-markers в этом блоге
и теперь мой поиск карт работает плавно на ipad-2:)