pmtiles-protocol v1.0.5
pmtiles-protocol
This package makes it easy to work with Protomaps PMTiles directly in the browser. It provides fetch and XMLHttpRequest versions that support urls starting with pmtiles://, returning the respective TileJSON or tiles. It is meant to be used in browser applications.
Supported URLs
TileJSON
pmtiles://https://example.com/path/to/mytiles.pmtiles(absolute)pmtiles://path/to/mytiles.pmtiles(relative towindow.location.href)
Tiles
pmtiles://https://example.com/path/to/mytiles.pmtiles/{z}/{x}/{y}.mvt(absolute)pmtiles://path/to/mytiles.pmtiles/{z}/{x}/{y}.mvt(relative towindow.location.href)
How to use
The global overrides for fetch() and XMLHttpRequest are the easiest way to use pmtiles-protocol:
import { register } from 'pmtiles-protocol';
const unregister = register();Now every request url that starts with pmtiles:// for anything in your web application that uses fetch() or XMLHttpRequest will go through pmtiles.
To restore the original global fetch() and XMLHttpRequest versions, call
unregister();If global overrides are not desired, pmtiles-protocol also provides a dedicated fetch() function and a dedicated XMLHttpRequest replacement:
import { fetch, XMLHttpRequest } from 'pmtiles-protocol';Examples
fetch
fetch('pmtiles://https://example.com/mytiles.pmtiles/0/0/0.mvt');fetches the 0/0/0 tile from the PMTiles file at https://example.com/mytiles.pmtiles.
XMLHttpRequest
const xhr = new XMLHttpRequest();
xhr.open('GET', 'pmtiles://path/to/mytiles.pmtiles');
xhr.onload = () => {
console.log('TileJSON', xhr.responseText);
};logs the TileJSON from the PMTiles file at path/to/mytiles.pmtiles (relative to window.location.href) to the console.
In a Mapbox Style document
The pmtiles source below will use the TileJSON and tiles from https://example.com/mytiles.pmtiles:
{
"sources": {
"pmtiles": {
"type": "vector",
"url": "pmtiles://https://example.com/mytiles.pmtiles"
}
}
}Limitations
This package won't add support for PMTiles when loading images by simply setting the src of an Image or HTTPImageElement. However, using an object url, the following would work:
const img = new Image();
fetch('pmtiles://path/to/mytiles.pmtiles/0/0/0.png')
.then((response) => response.blob())
.then((blob) => {
const objectUrl = URL.createObjectURL(blob);
img.onload = () => {
console.log('Image loaded');
URL.revokeObjectURL(objectUrl);
};
img.onerror = () => {
console.error('Image load error');
URL.revokeObjectURL(objectUrl);
};
img.src = objectUrl;
})
.catch((error) => {
console.error('Fetch error:', error);
});fetch()
No known limitations.
XMLHttpRequest
The limitations below only apply when XMLHttpRequest is used with a pmtiles:// url.
- Only the
loadanderrorevents are fired. - The only methods that act on the PMTiles file are
open()andsend(). - Only the
responseandresponseTextproperties are supported. - Only the
200and404status codes are used.