Попытка создать несколько информационных блоков в Картах Google, которые исчезают при нажатии новой
Я использую плагин infoboxes для карт Google. У меня они работают хорошо - когда человек нажимает на точку на карте, всплывающее окно не вызывает проблем. Однако я хотел бы, чтобы всплывающее окно исчезало при выборе другого маркера.
Я нашел несколько примеров того, как подойти к этой проблеме, но мне трудно интегрировать эти решения в мой код. Я довольно новичок в javascript, и я мог бы действительно использовать некоторые рекомендации!
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />
<title>Smelting</title>
<link
href="http://code.google.com/apis/maps/documentation/javascript/examples/default.css"
rel="stylesheet" type="text/css" />
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false&sfgdata=+sfgRmluamFuX1R5cGU9amF2YV9zY3JpcHQmRmluamFuX0xhbmc9dGV4dC9qYXZhc2NyaXB0+a"></script>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script type="text/javascript" src="http://google-maps-utility-library-v3.googlecode.com/svn/trunk/infobox/src/infobox.js"></script>
<style type="text/css">
.infoBox h2
{
font-size: 22px;
margin: 0 0 4px 2px;
}
.infoBox p
{
font-size: 14px;
margin: 0 2px;
}
.infoBox a
{
color:White;
text-decoration:none;
}
.infoBox p.sitenumber
{
font-size: 12px;
margin: 7px 0 2px 2px;
}
.siteButton
{
background-color: #465b66;
padding: 7px 10px;
text-align: center;
margin-top: 15px;
}
</style>
<script type="text/javascript">
function initialize() {
// Creating the map
var map = new google.maps.Map(document.getElementById("map_canvas"), {
mapTypeId: google.maps.MapTypeId.ROADMAP,
streetViewControl: false
});
// Styling the map
var styledMap = [{
featureType: "all",
stylers: [{
saturation: -80
}]
}, {
featureType: "road.arterial",
elementType: "geometry",
stylers: [{
hue: "#00ffee"
}, {
saturation: 50
}]
}, {
featureType: "poi.business",
elementType: "labels",
stylers: [{
visibility: "off"
}]
}
];
//Calling the map styles
map.setOptions({
styles: styledMap
});
// List of images
var images = [ 'images/icon1.png', 'images/icon2.png','images/icon3.png'];
loadMarkers();
// Zoom and center the map to fit the markers
var bounds = new google.maps.LatLngBounds();
// Create the markers
function addMarker(data, images) {
var marker = new google.maps.Marker({
position: new google.maps.LatLng(data.lat, data.long),
map: map,
title: data.name,
icon: images[--data["dot-type"]]
});
var myOptions = {
content: boxTitle
, boxStyle: {
color: "#fff"
, textAlign: "left"
, fontSize: "12pt"
, width: "250px"
, height: "230px"
, padding: "10px"
, fontFamily: "Arial"
, fontStyle: "bold"
, background : "transparent url( 'images/sampleback.png' ) no-repeat 0 0",
}
, disableAutoPan: true
, pixelOffset: new google.maps.Size(-90,-280)
, position: new google.maps.LatLng(data.lat, data.long)
, closeBoxURL: "http://www.google.com/intl/en_us/mapfiles/close.gif"
, isHidden: false
, pane: "floatPane"
};
var ib = new InfoBox(myOptions);
var boxTitle = document.createElement("div");
var boxNum = data.id;
var boxTitle= data.name;
var boxAddress = data.street;
var boxCity = data.city;
var boxSt = data.st;
var boxZip = data.zip;
var boxText = document.createElement("div");
boxText.content = "<p class='sitenumber'>" + "Site #" + boxNum + "</p>" +"<h2>"+boxTitle+"</h2>" + "<p>" + boxAddress + "</p>"+ "<p>" + boxCity + ", " + boxSt + " " + boxZip +"</p>" + "<b>" + "<a href='#'>" + "<div class= 'siteButton'>" + "VIEW THIS SITE DETAIL" + "</div>" + "</a>";
google.maps.event.addListener(marker, "click", function (event) {
ib.setContent(boxText.content);
ib.open(map, marker);
});
bounds.extend(new google.maps.LatLng(data.lat, data.long));
map.fitBounds(bounds);
}
function loadMarkers() {
var siteUrl = "data/main.js";
$.ajax({
dataType: "json",
url: siteUrl,
success: load
});
function load(data) {
for (index in data) addMarker(data[index], images);
}
};
}
</script>
</head>
<body onload="initialize()">
<div id="map_canvas"></div>
</body>
1 ответ
Причина, по которой для каждого маркера появляется одно окно, заключается в том, что вы создаете одно поле для каждого маркера. Если вам нужен только один блок, просто создайте его один раз и повторно используйте для каждого маркера. В вашем случае это просто включило бы помещение кода реализации вне функции addMarker:
<script type="text/javascript">
function initialize() {
// Creating the map
var map = new google.maps.Map(document.getElementById("map_canvas"), {
mapTypeId: google.maps.MapTypeId.ROADMAP,
streetViewControl: false
});
// Styling the map
var styledMap = [{
featureType: "all",
stylers: [{
saturation: -80
}]
}, {
featureType: "road.arterial",
elementType: "geometry",
stylers: [{
hue: "#00ffee"
}, {
saturation: 50
}]
}, {
featureType: "poi.business",
elementType: "labels",
stylers: [{
visibility: "off"
}]
}
];
//Calling the map styles
map.setOptions({
styles: styledMap
});
// List of images
var images = [ 'images/icon1.png', 'images/icon2.png','images/icon3.png'];
loadMarkers();
// Zoom and center the map to fit the markers
var bounds = new google.maps.LatLngBounds();
// Move the InfoBox creation here
var myOptions = {
content: boxTitle
, boxStyle: {
color: "#fff"
, textAlign: "left"
, fontSize: "12pt"
, width: "250px"
, height: "230px"
, padding: "10px"
, fontFamily: "Arial"
, fontStyle: "bold"
, background : "transparent url( 'images/sampleback.png' ) no-repeat 0 0",
}
, disableAutoPan: true
, pixelOffset: new google.maps.Size(-90,-280)
, position: new google.maps.LatLng(data.lat, data.long)
, closeBoxURL: "http://www.google.com/intl/en_us/mapfiles/close.gif"
, isHidden: false
, pane: "floatPane"
};
var ib = new InfoBox(myOptions);
// Create the markers
function addMarker(data, images) {
var marker = new google.maps.Marker({
position: new google.maps.LatLng(data.lat, data.long),
map: map,
title: data.name,
icon: images[--data["dot-type"]]
});
var boxTitle = document.createElement("div");
var boxNum = data.id;
var boxTitle= data.name;
var boxAddress = data.street;
var boxCity = data.city;
var boxSt = data.st;
var boxZip = data.zip;
var boxText = document.createElement("div");
boxText.content = "<p class='sitenumber'>" + "Site #" + boxNum + "</p>" +"<h2>"+boxTitle+"</h2>" + "<p>" + boxAddress + "</p>"+ "<p>" + boxCity + ", " + boxSt + " " + boxZip +"</p>" + "<b>" + "<a href='#'>" + "<div class= 'siteButton'>" + "VIEW THIS SITE DETAIL" + "</div>" + "</a>";
google.maps.event.addListener(marker, "click", function (event) {
ib.setContent(boxText.content);
ib.open(map, marker);
});
bounds.extend(new google.maps.LatLng(data.lat, data.long));
map.fitBounds(bounds);
}
function loadMarkers() {
var siteUrl = "data/main.js";
$.ajax({
dataType: "json",
url: siteUrl,
success: load
});
function load(data) {
for (index in data) addMarker(data[index], images);
}
};
}
</script>