States Tiles
Vector tiles for US state boundaries and labels. Ideal for thematic maps, state-level aggregations, and administrative overlays.
Endpoint
https://api.landmapmagic.com/v1/tiles/states/{z}/{x}/{y}.mvtReturns a Mapbox Vector Tile containing state polygon geometries and label points. Zoom range: 0 – 6.
URL Parameters
Parameters
| Name | Type | Description |
|---|---|---|
| z* | number | Zoom level (0-6). |
| x* | number | Tile X coordinate. |
| y* | number | Tile Y coordinate. |
| key* | string | Your API key. |
Source Layers
Source Layers
statesState polygon boundaries.z0-6states_labelsState label points (centroids).z0-6Attributes
Available Attributes
| Attribute | Type | Description |
|---|---|---|
| id | number | Unique internal feature identifier. |
| NAME | string | Full state name (e.g. "Iowa"). |
| STUSPS | string | Two-letter USPS state abbreviation (e.g. "IA"). |
| STATEFP | string | Two-digit FIPS state code (e.g. "19"). |
Code Examples
curl "https://api.landmapmagic.com/v1/tiles/states/4/3/6.mvt?key=YOUR_API_KEY" \
--output tile.mvtconst response = await fetch(
"https://api.landmapmagic.com/v1/tiles/states/4/3/6.mvt?key=YOUR_API_KEY"
);
const data = await response.arrayBuffer();
console.log("Tile size:", data.byteLength, "bytes");import requests
response = requests.get(
"https://api.landmapmagic.com/v1/tiles/states/4/3/6.mvt",
params={"key": "YOUR_API_KEY"}
)
print(f"Status: {response.status_code}, Size: {len(response.content)} bytes")Response
Response Headers
HTTP/1.1 200 OK
Content-Type: application/vnd.mapbox-vector-tile
Content-Encoding: gzip
Cache-Control: public, max-age=86400The response body is a binary MVT protobuf. Use a vector tile library such as deck.gl MVTLayer, Mapbox GL JS, or maplibre-gl to decode and render the tile.
Styles
Fetch a renderer-ready style for the States layer from the unified /v1/styles endpoint. The response includes sources, layers, attribution, zoom ranges, and label deduplication baked in. Use the landmapmagic npm package for one-line install per target, or call the API directly.
MapLibre / Mapbox
Identical payload either way — Mapbox GL JS consumes a MapLibre Style Spec v8 doc as-is. Pick the keyword that reads best in your codebase.
GET https://api.landmapmagic.com/v1/styles?target=maplibre&layers=states&key=YOUR_API_KEYGET https://api.landmapmagic.com/v1/styles?target=mapbox&layers=states&key=YOUR_API_KEYconst style = await fetch(
'https://api.landmapmagic.com/v1/styles?' +
new URLSearchParams({
key: 'YOUR_API_KEY',
target: 'maplibre', // or 'mapbox' — same response
layers: 'states',
})
).then((r) => r.json());
map.setStyle(style);Leaflet
GET https://api.landmapmagic.com/v1/styles?target=leaflet&layers=states&key=YOUR_API_KEYimport { mountLeafletLandMap } from 'landmapmagic/leaflet';
await mountLeafletLandMap({
apiKey: 'YOUR_API_KEY',
map,
layers: ['states'],
});Google + deck.gl
GET https://api.landmapmagic.com/v1/styles?target=google&layers=states&key=YOUR_API_KEYimport { mountGoogleLandMap } from 'landmapmagic/google';
await mountGoogleLandMap({
apiKey: 'YOUR_API_KEY',
map,
overlay,
layers: ['states'],
});