Learn with us how to create an amazing MapBox in HTML, CSS, and Javascript!
If you found us on TikTok on the following post, check out this article and copy-paste the full code!
Happy coding! 😻
@creative.tim Replying to @Mohaned 🫀 We can help you with that. 😎 Just check the Link in bio and create the coolest MapBox! #webdev #coding #programmer #mapbox #code ♬ original sound - Creative Tim
Contents:
1. HTML Code
2. CSS Code
3. Javascript Code
Get your code ⬇️
1. HTML Code
<script src='https://api.tiles.mapbox.com/mapbox-gl-js/v0.47.0/mapbox-gl.js'></script>
<link href='https://api.tiles.mapbox.com/mapbox-gl-js/v0.47.0/mapbox-gl.css' rel='stylesheet' />
<div id='map'></div>
2. CSS Code
body {
margin: 0;
padding: 0;
}
#map {
position: absolute;
top: 0;
bottom: 0;
width: 100%;
}
/* // From: Pitch toggle control for Mapbox GL JS — http://fuzzytolerance.info/blog/2017/01/30/Pitch-toggle-control-for-Mapbox-GL-JS/ */
.mapboxgl-ctrl-pitchtoggle-3d {
background-image: url();
}
.mapboxgl-ctrl-pitchtoggle-2d {
background-image: url();
}
/*
// the images for mapbox-gl-draw_* are from
https://github.com/mapbox/mapbox-gl-draw/blob/master/dist/mapbox-gl-draw.css
*/
.mapbox-gl-draw_point {
background-repeat: no-repeat;
background-position: center;
pointer-events: auto;
background-image: url();
}
.mapbox-gl-draw_line {
background-repeat: no-repeat;
background-position: center;
pointer-events: auto;
background-image: url();
}
.mapbox-gl-draw_polygon {
background-repeat: no-repeat;
background-position: center;
pointer-events: auto;
background-image: url();
}
3. Javascript Code
mapboxgl.accessToken =
"pk.eyJ1Ijoicm9ibGFicyIsImEiOiJwVlg0cnZnIn0.yhekddtKwZohGoORaWjqIw";
var map = new mapboxgl.Map({
container: "map", // container id
style: "mapbox://styles/mapbox/streets-v9", // stylesheet location
center: [-64.75, 32.3], // starting position [lng, lat]
zoom: 10 // starting zoom
});
// Original ES6 Class— https://github.com/tobinbradley/mapbox-gl-pitch-toggle-control
// export default class PitchToggle {
class PitchToggle {
constructor({ bearing = -20, pitch = 70, minpitchzoom = null }) {
this._bearing = bearing;
this._pitch = pitch;
this._minpitchzoom = minpitchzoom;
}
onAdd(map) {
this._map = map;
let _this = this;
this._btn = document.createElement("button");
this._btn.className = "mapboxgl-ctrl-icon mapboxgl-ctrl-pitchtoggle-3d";
this._btn.type = "button";
this._btn["aria-label"] = "Toggle Pitch";
this._btn.onclick = function() {
if (map.getPitch() === 0) {
let options = { pitch: _this._pitch, bearing: _this._bearing };
if (_this._minpitchzoom && map.getZoom() > _this._minpitchzoom) {
options.zoom = _this._minpitchzoom;
}
map.easeTo(options);
_this._btn.className =
"mapboxgl-ctrl-icon mapboxgl-ctrl-pitchtoggle-2d";
} else {
map.easeTo({ pitch: 0, bearing: 0 });
_this._btn.className =
"mapboxgl-ctrl-icon mapboxgl-ctrl-pitchtoggle-3d";
}
};
this._container = document.createElement("div");
this._container.className = "mapboxgl-ctrl-group mapboxgl-ctrl";
this._container.appendChild(this._btn);
return this._container;
}
onRemove() {
this._container.parentNode.removeChild(this._container);
this._map = undefined;
}
}
/* Idea from Stack Overflow https://stackoverflow.com/a/51683226 */
class MapboxGLButtonControl {
constructor({
className = "",
title = "",
eventHandler = evtHndlr
}) {
this._className = className;
this._title = title;
this._eventHandler = eventHandler;
}
onAdd(map) {
this._btn = document.createElement("button");
this._btn.className = "mapboxgl-ctrl-icon" + " " + this._className;
this._btn.type = "button";
this._btn.title = this._title;
this._btn.onclick = this._eventHandler;
this._container = document.createElement("div");
this._container.className = "mapboxgl-ctrl-group mapboxgl-ctrl";
this._container.appendChild(this._btn);
return this._container;
}
onRemove() {
this._container.parentNode.removeChild(this._container);
this._map = undefined;
}
}
/* Event Handlers */
function one(event) {
alert("Event handler when clicking on \r\n" + event.target.className);
console.log("event number 1", event);
}
function two(event) {
alert("Event handler when clicking on \r\n" + event.target.className);
console.log("event number 2", event);
}
function three(event) {
alert("Event handler when clicking on \r\n" + event.target.className);
console.log("event number 3", event);
}
/* Instantiate new controls with custom event handlers */
const ctrlPoint = new MapboxGLButtonControl({
className: "mapbox-gl-draw_point",
title: "Draw Point",
eventHandler: one
});
const ctrlLine = new MapboxGLButtonControl({
className: "mapbox-gl-draw_line",
title: "Draw Line",
eventHandler: two
});
const ctrlPolygon = new MapboxGLButtonControl({
className: "mapbox-gl-draw_polygon",
title: "Draw Polygon",
eventHandler: three
});
/* Add Controls to the Map */
map.addControl(new mapboxgl.NavigationControl(), "top-left");
map.addControl(new PitchToggle({ minpitchzoom: 11 }), "top-left");
map.addControl(ctrlPoint, "bottom-left");
map.addControl(ctrlLine, "bottom-right");
map.addControl(ctrlPolygon, "top-right");
I hope you did find this tutorial useful!
For more web development or UI/UX design tutorials, follow us on:
Other useful resources: