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.