From eab5b840cc4e89d9325395c9db8817520b53d995 Mon Sep 17 00:00:00 2001 From: Kevin Fabre Date: Thu, 7 Dec 2023 09:27:29 +0100 Subject: [PATCH] fix(POI Masps): add pixel ratio option for image Allow to support HDI displays --- packages/visualizations/src/components/MapPoi/Map.ts | 7 ++++--- packages/visualizations/src/components/MapPoi/types.ts | 4 +++- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/packages/visualizations/src/components/MapPoi/Map.ts b/packages/visualizations/src/components/MapPoi/Map.ts index 23a96ce4..96897e5d 100644 --- a/packages/visualizations/src/components/MapPoi/Map.ts +++ b/packages/visualizations/src/components/MapPoi/Map.ts @@ -326,11 +326,12 @@ export default class MapPOI { * Load images into the map. * Remove automatically any images previously loaded that are no longer defined in the images object. */ - loadImages(images?: Record) { + loadImages(images?: { [key: string]: string } & { pixelRatio?: number }) { if (!images) return; this.queue((map) => { + const { pixelRatio, ...rest } = images; const loadedImages = map.listImages(); - const imagesIds = Object.keys(images); + const imagesIds = Object.keys(rest); const imagesToRemove = difference(loadedImages, imagesIds); const imagesToAdd = difference(imagesIds, loadedImages); @@ -345,7 +346,7 @@ export default class MapPOI { // eslint-disable-next-line no-console console.warn(`Fail to load image: ${imageId}`); } else { - map.addImage(imageId, image); + map.addImage(imageId, image, { pixelRatio }); } }); }); diff --git a/packages/visualizations/src/components/MapPoi/types.ts b/packages/visualizations/src/components/MapPoi/types.ts index ec9fc0ef..fa1314b4 100644 --- a/packages/visualizations/src/components/MapPoi/types.ts +++ b/packages/visualizations/src/components/MapPoi/types.ts @@ -54,7 +54,7 @@ export interface PoiMapOptions { sourceLink?: Source; cooperativeGestures?: boolean | GestureOptions; /** Images to load by the Map. keys are image ids */ - images?: Record; + images?: { [key: string]: string } & { pixelRatio: number }; } export type PoiMapStyleOption = Partial>; @@ -94,6 +94,8 @@ export type CircleLayer = BaseLayer & { export type SymbolLayer = BaseLayer & { type: SymbolLayerSpecification['type']; + /** Scales the original size of the icon by the provided factor. */ + // iconSize: number, /** id of the image to use as icon-image */ iconImageId: string; /**