Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Current »

Summary

This guide provides step-by-step instructions on how to create, remove, and customise markers in your MazeMap JavaScript API project. It is intended to supplement the official MazeMap JS API documentation.

This example is intended to supplement the official MazeMap JS API documentation. For comprehensive details and further guidance, please refer to the MazeMap JS API documentation available at MazeMap JS API Docs.

Skill Level

Intermediate / JavaScript (JS) Programming

  • Basic to intermediate understanding of JavaScript and web development concepts.

  • Familiarity with handling events and manipulating objects in JavaScript.

Prerequisites

Before you begin, ensure the following:

  • Confirm that all relevant scripts are included in your HTML or JavaScript files.

  • MazeMap API and map is fully loaded into your project by using the Map load function.

  • You have a variable referencing the loaded map. This variable is typically initialised when you create the map instance.

Creating Markers

Adding a Marker

To add a marker, you need the location LngLat coordinates. If adding an 'indoor' marker, you also need to know the indoor floor 'z level'. In this example, we use the map center as our marker coordinates.

var lngLat = map.getCenter(); 

var marker = new Mazemap.MazeMarker({ 
  zLevel: 1 // The floor zLevel coordinate 
}) 

.setLngLat(lngLat) // Set the LngLat coordinates 
.addTo(map); // Add to the map

Removing Markers

Removing a Marker

To remove a marker, simply use the remove() function.

marker.remove();

Removing Multiple Markers

If you have added multiple markers and want to clear all of them on your map, you can loop over all markers and delete them one by one.

if (currentMarkers !== null) { 
  for (var i = currentMarkers.length - 1; i >= 0; i--) { 
    currentMarkers[i].remove(); 
  } 
}

Here, currentMarkers is a global variable containing all markers.

var currentMarkers = []; 
var oneMarker = new mapboxgl.Marker(currentMarkerDiv) 
  .setLngLat(marker.geometry.coordinates) 
  .addTo(map); currentMarkers.push(oneMarker);

Customizing Markers with Mapbox JS API

For advanced marker customisation, you can reference the Mapbox JS API documentation.

Customise marker styles, colors, and behaviour using Mapbox's extensive styling options.

Example: Mouse Over Popup

Add a popup that appears when hovering over a marker.

var popup = new mapboxgl.Popup({ offset: 25 }).setText('Marker Info'); 
marker.setPopup(popup);

Example: Mouse Over Color Change

Change the marker color when hovering over it.

var defaultColor = 'blue'; 
var hoverColor = 'red'; 

marker.getElement().style.backgroundColor = defaultColor; 

marker.getElement().addEventListener('mouseover', function() { 
  marker.getElement().style.backgroundColor = hoverColor; 
}); 

marker.getElement().addEventListener('mouseout', function() { 
  marker.getElement().style.backgroundColor = defaultColor; 
});

Conclusion

Handling markers in your MazeMap using the JavaScript API allows for greater control over map customisation and can enhance user interaction. Follow this guide to effectively manage markers in your MazeMap applications.

This example is intended to supplement the official MazeMap JS API documentation. For comprehensive details and further guidance, please refer to the MazeMap JS API documentation available at MazeMap JS API Docs.

  • No labels