mirror of
https://github.com/maplibre/martin.git
synced 2024-12-19 04:41:46 +03:00
66b7fdc4ea
Partial implementation of the #430 * New endpoint structure: * `GET /` -- a placeholder for the future home page * `GET /catalog` -- get a list of available sources, as a list of json blobs. * `[{id, name, description, attribution, vector_layer}, ...]` (some fields might be missing) * `GET /<id>` -- get tilejson for the given source, or a combination of sources. No `.json` extension * `GET /<id>/<z>/<x>/<y>` -- get a tile. No format extension. * `GET /health` -- healthcheck * Introduce a new tile format support crate (using code from the maplibre/mbtileserve project) * Removed the `/rpc/...` routes - all source IDs are accessed in the same way * Can print auto-generated configuration or save it to a file * Refactored to support multiple sources from multiple backends, with a proper naming conflict resolution TODO: * benchmarks need to be rewritten - they were relying on some internal structures that are no longer there. This might be done as a separate PR due to a very different internal architecture - might need to rethink benchmarking approaches.
62 lines
1.6 KiB
HTML
62 lines
1.6 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<title>Martin Debug Page</title>
|
|
<meta
|
|
name="viewport"
|
|
content="initial-scale=1,maximum-scale=1,user-scalable=no"
|
|
/>
|
|
<script src="https://unpkg.com/deck.gl@^8.4.0/dist.min.js"></script>
|
|
<script src="https://unpkg.com/maplibre-gl@2.1.9/dist/maplibre-gl.js"></script>
|
|
<link href="https://unpkg.com/maplibre-gl@2.1.9/dist/maplibre-gl.css" rel="stylesheet" />
|
|
|
|
<style>
|
|
body {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
#map {
|
|
width: 100vw;
|
|
height: 100vh;
|
|
}
|
|
</style>
|
|
</head>
|
|
|
|
<body>
|
|
<div id="map"></div>
|
|
|
|
<script>
|
|
const deckgl = new deck.DeckGL({
|
|
container: 'map',
|
|
map: maplibregl,
|
|
mapStyle: 'https://basemaps.cartocdn.com/gl/dark-matter-gl-style/style.json',
|
|
initialViewState: {
|
|
latitude: 0,
|
|
longitude: 0,
|
|
zoom: 3,
|
|
pitch: 40
|
|
},
|
|
controller: true,
|
|
layers: [
|
|
new deck.MVTLayer({
|
|
data: 'http://localhost:3000/points',
|
|
uniqueIdProperty: 'gid',
|
|
getFillColor: f => {
|
|
const alpha = f.geometry.coordinates[1] * 255;
|
|
return f.properties.gid % 2 === 0 ? [51, 204, 204, alpha] : [255, 128, 223, alpha]
|
|
},
|
|
getRadius: f => Math.sqrt(f.properties.gid) / 12,
|
|
pointRadiusUnits: 'pixels',
|
|
pickable: true,
|
|
autoHighlight: true,
|
|
highlightColor: [102, 255, 153],
|
|
onClick: info => console.log(info.object)
|
|
})
|
|
],
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|