Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8' />
<title>cartobq.maps.ookla2 | CARTO BigQuery Tiler</title>
<meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />
<script src='https://storage.googleapis.com/bqtilerjslibs/mbgl1.12.0.js'></script>
<link href='https://storage.googleapis.com/bqtilerjslibs/mbgl1.12.0.css' rel='stylesheet' />
<link href="https://fonts.googleapis.com/css2?family=Open+Sans&display=swap" rel="stylesheet">
<style>
* {
box-sizing: border-box;
}
body { display: flex; flex-direction: column; height: 100vh; margin:0; padding:0; }
#map {
position:absolute;
top:0;
left:0;
height: 100%;
width: 100%;
border-radius: 8px;
/* border: 8px solid #f2f6f9;
border-bottom: none; */
}
.map-container {
position: relative;
border: 8px solid #f2f6f9;
border-bottom: none;
border-radius: 8px;
overflow: hidden;
height: 100%;
background-color: #f2f6f9;
}
.map-footer {
display: flex;
padding: 8px;
justify-content: space-between;
align-items: center;
flex-grow: 0;
flex-shrink: 0;
/* height: 20px; */
width: 100%;
font-family: 'Open Sans', sans-serif;
background-color: #f2f6f9;
}
.map-footer p {
font-size: 12px;
line-height: 16px;
margin: 0;
}
.map-footer img {
height: 16px;
width: 16px;
vertical-align: middle;
}
#info {
position: absolute;
margin: 16px;
z-index: 1;
}
</style>
</head>
<body>
<span id="info"></span>
<div class="map-container">
<div id="map"></div>
</div>
<div class="map-footer">
<div>
<p>
<img src="" alt="CARTO heart"/>
Created with <a href="https://carto.com/bigquery/beta/" target="_blank" style="color: #1785fb">
CARTO BigQuery Tiler</a></p>
</div>
<div>
<a href="https://carto.com" target="_blank">
<svg viewBox="0 0 62 24" height="24" width="62" style="display: block;">
<g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<path d="M3.94693333,15.9877346 C5.63066667,15.9877346 6.60373333,15.2552013 7.32533333,14.260268 L5.72906667,13.1232013 C5.26986667,13.6808013 4.79973333,14.0525346 4.0016,14.0525346 C2.93013333,14.0525346 2.17573333,13.1560013 2.17573333,12.0080013 L2.17573333,11.9861346 C2.17573333,10.8709346 2.93013333,9.95253464 4.0016,9.95253464 C4.73413333,9.95253464 5.23706667,10.3133346 5.6744,10.849068 L7.27066667,9.6136013 C6.5928,8.68426797 5.58693333,8.02826797 4.02346667,8.02826797 C1.7056,8.02826797 0,9.7776013 0,12.0080013 L0,12.029868 C0,14.3149346 1.76026667,15.9877346 3.94693333,15.9877346 L3.94693333,15.9877346 Z M10.93653,15.834668 L13.1559967,15.834668 L13.7026634,14.457068 L16.6655967,14.457068 L17.2122634,15.834668 L19.4863967,15.834668 L16.2282634,8.12666797 L14.18373,8.12666797 L10.93653,15.834668 Z M14.3258634,12.8061346 L15.1895967,10.6413346 L16.0423967,12.8061346 L14.3258634,12.8061346 Z M23.61653,15.834668 L25.7375966,15.834668 L25.7375966,13.5168013 L26.6778633,13.5168013 L28.2194633,15.834668 L30.6575966,15.834668 L28.83173,13.1669346 C29.78293,12.7624013 30.40613,11.9861346 30.40613,10.8053346 L30.40613,10.783468 C30.40613,10.029068 30.17653,9.4496013 29.7282633,9.00133464 C29.2143966,8.48746797 28.40533,8.18133464 27.2354633,8.18133464 L23.61653,8.18133464 L23.61653,15.834668 Z M25.7375966,11.8549346 L25.7375966,10.0072013 L27.1370633,10.0072013 C27.8367966,10.0072013 28.2850633,10.3133346 28.2850633,10.9256013 L28.2850633,10.947468 C28.2850633,11.505068 27.8586633,11.8549346 27.1479966,11.8549346 L25.7375966,11.8549346 Z M36.7338633,15.834668 L38.8549299,15.834668 L38.8549299,10.0400013 L41.1509299,10.0400013 L41.1509299,8.18133464 L34.4487966,8.18133464 L34.4487966,10.0400013 L36.7338633,10.0400013 L36.7338633,15.834668 Z" fill="#162945"></path>
<g transform="translate(37.000000, 0.000000)">
<circle fill="rgba(22,41,69,.1)" cx="12.3333333" cy="12" r="12"></circle>
<path d="M12.3333333,16.5 C14.8186147,16.5 16.8333333,14.4852814 16.8333333,12 C16.8333333,9.51471863 14.8186147,7.5 12.3333333,7.5 C9.84805196,7.5 7.83333333,9.51471863 7.83333333,12 C7.83333333,14.4852814 9.84805196,16.5 12.3333333,16.5 L12.3333333,16.5 Z" fill="#162945"></path>
</g>
</g>
</svg>
</a>
</div>
</div>
<script>
const queryString = window.location.search;
const urlParams = new URLSearchParams(queryString);
let zoom = 0;
let center = [0, 0];
let customCenterZoom = false;
const info = urlParams.get('info') !== null;
try {
center = [parseFloat(urlParams.get('c').split(',')[0]),parseFloat(urlParams.get('c').split(',')[1])];
zoom = parseInt(urlParams.get('z'));
customCenterZoom = true;
} catch(e) {}
const map = new mapboxgl.Map({
container: 'map',
style: 'https://basemaps.cartocdn.com/gl/positron-gl-style/style.json',
center,
zoom
});
map.addControl(new mapboxgl.NavigationControl({showCompass: false}), 'bottom-left');
map.on('style.load', () => {
cartoSource = {
type: 'vector',
maxzoom: 8,
tiles: ["https://bq1.cartocdn.com/tile?y={y}&x={x}&z={z}&p=0_8_0_255_21_236_4000_1&t=cartobq.maps.ookla2","https://bq2.cartocdn.com/tile?y={y}&x={x}&z={z}&p=0_8_0_255_21_236_4000_1&t=cartobq.maps.ookla2","https://bq3.cartocdn.com/tile?y={y}&x={x}&z={z}&p=0_8_0_255_21_236_4000_1&t=cartobq.maps.ookla2","https://bq4.cartocdn.com/tile?y={y}&x={x}&z={z}&p=0_8_0_255_21_236_4000_1&t=cartobq.maps.ookla2"]
};
map.addSource('cartoSource', cartoSource);
const paintStyleForAggregatedTotal = {
"circle-color": {
"property": "aggregated_total",
"type": "exponential",
"stops": [
[
{"zoom": 0, "value": 1},
"rgba(0, 147, 146, 1)"
],
[
{"zoom": 0, "value": 10},
"rgba(57, 177, 133, 1)"
],
[
{"zoom": 0, "value": 100},
"rgba(156, 203, 134, 1)"
],
[
{"zoom": 0, "value": 1000},
"rgba(233, 226, 156, 1)"
],
[
{"zoom": 0, "value": 10000},
"rgba(238, 180, 121, 1)"
],
[
{"zoom": 0, "value": 100000},
"rgba(232, 132, 113, 1)"
],
[
{"zoom": 0, "value": 1000000},
"rgba(207, 89, 126, 1)"
]
]
},
"circle-radius": {
"stops": [[0, 2.2], [0.99, 2.6]]
},
"circle-opacity": 1,
"circle-blur": 0
};
const paintStyleForSimplePoints = {
"circle-color": "rgba(209, 7, 218, 1)",
"circle-radius": {
"stops": [[0, 2.2], [0.99, 2.6]]
},
"circle-opacity": 0.6,
"circle-blur": 0,
"circle-stroke-opacity": 0
};
const paintStyleForLines = {
"line-color": "rgba(76, 200, 163, 1)",
"line-opacity": 0.8
};
const paintStyleForSimpleCells = {
"fill-color": "rgba(244, 0, 245, 1)",
"fill-opacity": 0.4
};
const paintStyleForAggregatedCells = {
"fill-color": {
"property": "aggregated_total",
"type": "exponential",
"stops": [
[
{"zoom": 0, "value": 1},
"rgba(0, 147, 146, 1)"
],
[
{"zoom": 0, "value": 7849},
"rgba(57, 177, 133, 1)"
],
[
{"zoom": 0, "value": 19352},
"rgba(156, 203, 134, 1)"
],
[
{"zoom": 0, "value": 35792},
"rgba(233, 226, 156, 1)"
],
[
{"zoom": 0, "value": 63093},
"rgba(238, 180, 121, 1)"
],
[
{"zoom": 0, "value": 114731},
"rgba(232, 132, 113, 1)"
],
[
{"zoom": 0, "value": 946894},
"rgba(207, 89, 126, 1)"
]
]
},
"fill-opacity": 0.8
};
if (info) {
map.on('zoom', () => {
const zoom = map.getZoom().toFixed(4);
document.getElementById('info').innerText = 'Zoom: ' + zoom;
});
}
map.addLayer({
'id': 'bqtiler',
'type': 'fill',
'source': 'cartoSource',
'source-layer': 'default',
'paint': paintStyleForAggregatedCells
},'place_town');
if(!customCenterZoom) {
map.setZoom(3);
map.setCenter([1.1426778436779677,32.738827982997734]);
}
});
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment