Skip to content

Commit

Permalink
Read attribute from metadata
Browse files Browse the repository at this point in the history
  • Loading branch information
katamartin committed Mar 26, 2024
1 parent 9fa3ee3 commit 1b2762a
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 4 deletions.
5 changes: 3 additions & 2 deletions src/initialize-store.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ const initializeStore = async (source, version, variable, coordinateKeys) => {
resolve()
})
)
;({ levels, maxZoom, tileSize } = getPyramidMetadata(
;({ levels, maxZoom, tileSize, crs } = getPyramidMetadata(
metadata.metadata['.zattrs'].multiscales
))

Expand All @@ -48,7 +48,7 @@ const initializeStore = async (source, version, variable, coordinateKeys) => {
break
case 'v3':
metadata = await fetch(`${source}/zarr.json`).then((res) => res.json())
;({ levels, maxZoom, tileSize } = getPyramidMetadata(
;({ levels, maxZoom, tileSize, crs } = getPyramidMetadata(
metadata.attributes.multiscales
))

Expand Down Expand Up @@ -114,6 +114,7 @@ const initializeStore = async (source, version, variable, coordinateKeys) => {
levels,
maxZoom,
tileSize,
crs,
}
}

Expand Down
6 changes: 5 additions & 1 deletion src/tiles.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,6 @@ export const createTiles = (regl, opts) => {
this.variable = variable
this.fillValue = fillValue
this.projection = projection
this.projectionIndex = ['mercator', 'equirectangular'].indexOf(projection)
this.order = order ?? [1, 1]
this.invalidate = invalidate
this.viewport = { viewportHeight: 0, viewportWidth: 0 }
Expand Down Expand Up @@ -117,13 +116,18 @@ export const createTiles = (regl, opts) => {
levels,
maxZoom,
tileSize,
crs,
}) => {
if (setMetadata) setMetadata(metadata)
this.maxZoom = maxZoom
this.level = zoomToLevel(this.zoom, maxZoom)
const position = getPositions(tileSize, mode)
this.position = regl.buffer(position)
this.size = tileSize
// Respect `projection` prop when provided, otherwise rely on `crs` value from metadata
this.projectionIndex = projection
? ['mercator', 'equirectangular'].indexOf(projection)
: ['EPSG:3857', 'EPSG:4326'].indexOf(crs)
if (mode === 'grid' || mode === 'dotgrid') {
this.count = position.length
}
Expand Down
10 changes: 9 additions & 1 deletion src/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -349,13 +349,21 @@ export const getPyramidMetadata = (multiscales) => {
const levels = datasets.map((dataset) => Number(dataset.path))
const maxZoom = Math.max(...levels)
const tileSize = datasets[0].pixels_per_tile
let crs = datasets[0].crs

if (!tileSize) {
throw new Error(
'Missing required `pixels_per_tile` value in `multiscales` metadata. Please check your pyramid generation code.'
)
}
return { levels, maxZoom, tileSize }

if (!crs) {
console.warn(
'Missing `crs` value in `multiscales` metadata. Please check your pyramid generation code. Falling back to `crs=EPSG:3857` (Web Mercator)'
)
crs = 'EPSG:3857'
}
return { levels, maxZoom, tileSize, crs }
}

/**
Expand Down

0 comments on commit 1b2762a

Please sign in to comment.