<html>
<head>
<meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />
<meta charset=utf-8 />
<title>Quake | Mapbox</title>
<link rel='shortcut icon' href='path/to/favicon.ico' type='image/x-icon' />
<script src='https://api.mapbox.com/mapbox-gl-js/v0.42.0/mapbox-gl.js'></script>
<link href='https://api.mapbox.com/mapbox-gl-js/v0.42.0/mapbox-gl.css' rel='stylesheet' />
</head>
<body style="position: absolute; left: 0; bottom: 0; right: 0; top: 0;">
<div id='map' style="position: absolute; left: 0; bottom: 0; right: 0; top: 0;"></div>
<script>
// Assign globals
mapboxgl.accessToken = '{your token}';
const interval = 500;
let offsetVal = 2;
// Initialize map
const map = new mapboxgl.Map({
container: 'map',
style: '{your style id}'
});
// Function called by animate() to create property transitions
function updateProperty(layer, property, value, timeoutModifier) {
setTimeout(function() {
map.setPaintProperty(layer, property, value);
}, interval * timeoutModifier);
}
// Function to call at each interval
function animate() {
// invert offsetVal every animation loop
offsetVal = offsetVal * -1;
updateProperty('place-label', 'text-translate', [0, offsetVal * -1], 1.5);
updateProperty('contour-lines', 'line-offset', offsetVal, 0);
}
// Minor tweaks to map & kick off the animation loop
map.on('load', function() {
// Update transition property on map style to match animation loop time
const mapStyle = map.getStyle();
mapStyle.transition = {
duration: interval,
delay: 0
};
map.setStyle(mapStyle);
// Start animation
setInterval(animate, interval);
});
</script>
</body>
</html>
Output
You can jump to the latest bin by adding /latest
to your URL
Keyboard Shortcuts
Shortcut | Action |
---|---|
ctrl + [num] | Toggle nth panel |
ctrl + 0 | Close focused panel |
ctrl + enter | Re-render output. If console visible: run JS in console |
Ctrl + l | Clear the console |
ctrl + / | Toggle comment on selected lines |
ctrl + ] | Indents selected lines |
ctrl + [ | Unindents selected lines |
tab | Code complete & Emmet expand |
ctrl + shift + L | Beautify code in active panel |
ctrl + s | Save & lock current Bin from further changes |
ctrl + shift + s | Open the share options |
ctrl + y | Archive Bin |
Complete list of JS Bin shortcuts |
JS Bin URLs
URL | Action |
---|---|
/ | Show the full rendered output. This content will update in real time as it's updated from the /edit url. |
/edit | Edit the current bin |
/watch | Follow a Code Casting session |
/embed | Create an embeddable version of the bin |
/latest | Load the very latest bin (/latest goes in place of the revision) |
/[username]/last | View the last edited bin for this user |
/[username]/last/edit | Edit the last edited bin for this user |
/[username]/last/watch | Follow the Code Casting session for the latest bin for this user |
/quiet | Remove analytics and edit button from rendered output |
.js | Load only the JavaScript for a bin |
.css | Load only the CSS for a bin |
Except for username prefixed urls, the url may start with http://jsbin.com/abc and the url fragments can be added to the url to view it differently. |