This class extends BaseClass.
The marker cluster helps you to add bunch of markers on the map. Closed-locations are clustered to one marker, and the clustered marker displays the number of markers.
If you click on the clustered marker, the map zooms-in to the bounds that contains all markers in that area.
The map.addMarkerCluster() method creates an instance marker cluster onto the map.
- The
markers
andicons
properties are required. - This method works after the MAP_READY event.
var options = {
'camera': {
'target': dummyData()[0].position,
'zoom': 12
}
};
var map = plugin.google.maps.Map.getMap(mapDiv, options);
map.on(plugin.google.maps.event.MAP_READY, function() {
//------------------------------------------------------
// Create a marker cluster.
// Providing all locations at the creating is the best.
//------------------------------------------------------
map.addMarkerCluster({
markers: dummyData(),
icons: [
{min: 2, max: 100, url: "./img/blue.png", anchor: {x: 16, y: 16}},
{min: 100, max: 1000, url: "./img/yellow.png", anchor: {x: 16, y: 16}},
{min: 1000, max: 2000, url: "./img/purple.png", anchor: {x: 24, y: 24}},
{min: 2000, url: "./img/red.png",anchor: {x: 32,y: 32}}
]
}, function (markerCluster) {
// somethings you want to do...
});
});
function dummyData() {
return [
{
"position": {
"lat": 21.382314,
"lng": -157.933097
},
"name": "Starbucks - HI - Aiea 03641",
"address": "Aiea Shopping Center_99-115 Aiea Heights Drive #125_Aiea, Hawaii 96701",
"phone": "808-484-0000",
"icon": "./img/starbucks.png"
},
...
...
...
{
"position": {
"lat": 21.3871,
"lng": -157.9482
},
"name": "Starbucks - HI - Aiea 03642",
"address": "Pearlridge Center_98-125 Kaonohi Street_Aiea, Hawaii 96701",
"phone": "808-484-0000",
"icon": "./img/starbucks.png"
}
]
}
You can specify a few style options.
// Available options
var labelOptions = {
bold: true,
fontSize: 15,
color: "white",
italic: true
};
map.addMarkerCluster({
markers: dummyData(),
icons: [
{min: 2, max: 100, url: "./img/blue.png", anchor: {x: 16, y: 16}, label: labelOptions},
{min: 100, max: 1000, url: "./img/yellow.png", anchor: {x: 16, y: 16}, label: labelOptions},
{min: 1000, max: 2000, url: "./img/purple.png", anchor: {x: 24, y: 24}, label: labelOptions},
{min: 2000, url: "./img/red.png",anchor: {x: 32,y: 32}, label: labelOptions}
]
}, function (markerCluster) {
});
As well as regular marker, you can store your custom data, then get them later.
map.addMarkerCluster({
markers: dummyData(),
icons: [
{min: 2, max: 100, url: "./img/blue.png", anchor: {x: 16, y: 16}, label: labelOptions},
{min: 100, max: 1000, url: "./img/yellow.png", anchor: {x: 16, y: 16}, label: labelOptions},
{min: 1000, max: 2000, url: "./img/purple.png", anchor: {x: 24, y: 24}, label: labelOptions},
{min: 2000, url: "./img/red.png",anchor: {x: 32,y: 32}, label: labelOptions}
]
}, function (markerCluster) {
markerCluster.on(plugin.google.maps.event.MARKER_CLICK, function (position, marker) {
alert(marker.get("name"));
});
});
If you want to remove the red box, you just set boundsDraw = false
.
map.addMarkerCluster({
boundsDraw: false
markers: dummyData(),
icons: [
{min: 2, max: 100, url: "./img/blue.png", anchor: {x: 16, y: 16}},
{min: 100, max: 1000, url: "./img/yellow.png", anchor: {x: 16, y: 16}},
{min: 1000, max: 2000, url: "./img/purple.png", anchor: {x: 24, y: 24}},
{min: 2000, url: "./img/red.png",anchor: {x: 32,y: 32}}
]
}, function (markerCluster) {
});
map.addMarkerCluster() | Add a marker cluster. |
---|
addMarker() | Add one location. |
---|---|
addMarkers() | Add multiple locations. |
remove() | Remove the marker cluster. |
MARKER_CLICK | Arguments: LatLng, Marker This event is fired when you click on a marker. |
---|