You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Update MapML.HTMLMapmlViewerElement.matchMedia(mq) en documentation
Update extension content preference section and links to/from
Added French translations
Update images of extension to show multiple preferred content selection
Copy file name to clipboardexpand all lines: docs/api/mapml-viewer-api.mdx
+100-1
Original file line number
Diff line number
Diff line change
@@ -222,6 +222,7 @@ let zoom = map.zoom;
222
222
|[defineCustomProjection(options)](#definecustomprojectionoptions)| Define a custom projection for use by the page. |
223
223
|[zoomTo(lat, lon, zoom)](#zoomtolat-lon-zoom)| Fly or pan the map to a (new) location and zoom level.|
224
224
|[geojson2mapml(json, options)](#zoomtolat-lon-zoom)| Add a GeoJSON Layer to the map. |
225
+
| [matchMedia(mediaQueryString)](#matchmediamediaquerystring) | Returns a [MediaQueryList](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList)-like object.
225
226
226
227
227
228
### back()
@@ -358,6 +359,32 @@ Check out [this application](https://maps4html.org/experiments/api/custom-map-ui
358
359
359
360
---
360
361
362
+
### matchMedia(mediaQueryString)
363
+
364
+
While not strictly 'media' features, some dynamic map properties can be combined in queries with standard media features, for example the 'prefers-color-scheme' feature,
365
+
to enable a map container / media-query-like interface.
366
+
367
+
`matchMedia(mediaQueryString)` returns a [MediaQueryList-like object](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList).
368
+
The `matches` boolean-valued property of the object can be used for an immediate determination of whether the map meets the queried feature conditions. To react to changes in
369
+
the map state / media conditions, use MediaQueryList.addEventListener('change', callbackFn) to add an event listener for `change` events that are triggered by changes in the
370
+
state of the queried map properties (projection, zoom, extent); any change to the map that results in a change in state of the [MediaQueryListEvent `matches` boolean property](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList/change_event)triggers the `change` event and calls the callbackFn.
371
+
372
+
## Supported map 'media' query features
373
+
374
+
| Feature name | Description |
375
+
|------------------|-------------|
376
+
| map-zoom | Range of integers Used to evaluate if map-zoom is of a certain value or within a range |
377
+
| map-projection | Discrete string values - known values include `OSMTILE`, `CBMTILE`, `WGS84`, `APSTILE`. Can be extended with [custom projections](#definecustomprojectionoptions). |
378
+
| map-top-left-easting | Range of integers - **Decimal values are not supported.**|
379
+
| map-top-left-northing | Range of integers - **Decimal values are not supported.**|
380
+
| map-bottom-right-easting | Range of integers - **Decimal values are not supported.**|
381
+
| map-bottom-right-northing | Range of integers - **Decimal values are not supported.**|
382
+
| prefers-map-content | Discrete string values - supported values include: `image`, `tile`, `feature`, `table`. Preferences can be established via multi-select in the [MapML browser extension](../extension/features#select-map-content-preferences)|
383
+
| prefers-color-scheme | Discrete string values - supported values are `light` and `dark`|
384
+
| prefers-lang | 2-character language code returned by `navigator.language`, based on user's browser display language setting |
385
+
386
+
---
387
+
361
388
## Events
362
389
363
390
| Event name | Description |
@@ -617,7 +644,7 @@ let output = map.geojson2mapml(json);
// Format the media query string to detect overlap:
701
+
// (xminm < xmaxq) and (xmaxm > xminq) and (yminm < ymaxq) and (ymaxm > yminq)
702
+
constquery=`(map-projection: OSMTILE) and (7 < map-zoom < 14) and (map-top-left-easting < ${bottomRightEasting}) and (map-bottom-right-easting > ${topLeftEasting}) and (map-bottom-right-northing < ${topLeftNorthing}) and (map-top-left-northing > ${bottomRightNorthing})`;
703
+
704
+
constmatcher=map.matchMedia(query);
705
+
706
+
// create a layer to visually represent the query as the map moves
707
+
constf=`<map-layer checked label="test media query"><map-meta name="projection" content="OSMTILE"></map-meta>
[Report problems with these requirements on GitHub](https://github.com/Maps4HTML/HTML-Map-Element-UseCases-Requirements/issues/new?title=-SUMMARIZE+THE+PROBLEM-&body=-DESCRIBE+THE+PROBLEM-)
Copy file name to clipboardexpand all lines: i18n/fr/docusaurus-plugin-content-docs/current/api/mapml-viewer-api.mdx
+93-1
Original file line number
Diff line number
Diff line change
@@ -225,6 +225,7 @@ let zoom = map.zoom;
225
225
|[defineCustomProjection(options)](#definecustomprojectionoptions)| Définir une projection personnalisée à utiliser par la page. |
226
226
|[zoomTo(lat, lon, zoom)](#zoomtolat-lon-zoom)| Survole la carte ou effectue un mouvement panoramique vers un (nouvel) emplacement et à un autre niveau de zoom.|
227
227
|[geojson2mapml(json, options)](#zoomtolat-lon-zoom)| Convertit une caractéristique GeoJSON ou une chaîne ou un objet de collection de caractéristiques en élément MapML `<map-layer>` contenant un ou plusieurs éléments `<map-feature>`. |
228
+
|[matchMedia(mediaQueryString)](#matchmediamediaquerystring)| Renvoie un objet similaire à [MediaQueryList](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList). |
228
229
229
230
230
231
### back()
@@ -360,6 +361,28 @@ Jetez un coup d’œil à [cette application](https://maps4html.org/experiments/
360
361
| <spanid="option-properties">`properties`</span> |\<Function \| String \| HTMLElement\>|_Les propriétés seront mappées à un [table](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/table) HTML._| Précise la façon dont les propriétés sont mappées. \<Function\> - Fonction qui accepte un argument – l’objet GeoJSON feature – et qui doit retourner un HTMLElement qui devient l’unique élément-enfant de \<properties\>. \<String\> - Chaîne qui sera analysée syntaxiquement et utilisée comme unique élément-enfant de `<properties>` avec toutes les caractéristiques. \<HTMLElement\> - Élément qui servira d’unique élément- enfant de `<properties>` avec toutes les caractéristiques. Voir la section [utilisation des options de base](#utilisation-des-options-de-base) pour un exemple.|
361
362
|`geometryFunction`|\<Function\>| La géométrie _MapML reproduit la valeur géométrique GeoJSON_|\<Function\> Fonction pour modifier les [descendants générés](https://maps4html.org/web-map-doc/docs/elements/geometry/#child-elements) de `<map-geometry>` qui peut ajouter des classes, [hyperlinks](https://maps4html.org/web-map-doc/docs/elements/map-a/) et des [spans](https://maps4html.org/web-map-doc/docs/elements/span/) à l’instance. Un élément `<map-geometry>` simple est créé par défaut. La fonction accepte deux arguments : l’[élément-enfant généré](https://maps4html.org/web-map-doc/docs/elements/geometry/#child-elements) de `<map-geometry>` et [l’objet de la caractéristique JSON](https://www.rfc-editor.org/rfc/rfc7946#section-3.2) pour retourner un élément-enfant modifié de `<map-geometry>`. Voir la section [Utilisation des options de base](#utilisation-des-options-de-base) pour un exemple. |
362
363
364
+
---
365
+
366
+
### matchMedia(mediaQueryString)
367
+
368
+
Bien que cela ne soit pas strictement des fonctionnalités "média", certaines propriétés dynamiques de la carte peuvent être combinées dans des requêtes avec des fonctionnalités média standard, comme la fonctionnalité 'prefers-color-scheme', pour permettre une interface de type conteneur de carte / requête média.
369
+
370
+
`matchMedia(mediaQueryString)` renvoie un [objet similaire à MediaQueryList](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList). La propriété booléenne `matches` de l'objet peut être utilisée pour déterminer immédiatement si la carte répond aux conditions des fonctionnalités requises. Pour réagir aux changements dans l'état de la carte ou des conditions média, utilisez `MediaQueryList.addEventListener('change', callbackFn)` pour ajouter un écouteur d'événements aux événements `change` déclenchés par les modifications de l'état des propriétés de la carte interrogées (projection, zoom, étendue). Tout changement de la carte qui entraîne une modification de l'état de la propriété booléenne `matches` de [MediaQueryListEvent](https://developer.mozilla.org/en-US/docs/Web/API/MediaQueryList/change_event) déclenche l'événement `change` et appelle la fonction `callbackFn`.
371
+
372
+
## Fonctionnalités de requête "média" prises en charge pour la carte
| map-zoom | Gamme d'entiers utilisée pour évaluer si `map-zoom` a une certaine valeur ou se situe dans une plage |
377
+
| map-projection | Valeurs discrètes de chaîne - les valeurs connues incluent `OSMTILE`, `CBMTILE`, `WGS84`, `APSTILE`. Peut être étendu avec des [projections personnalisées](#definecustomprojectionoptions). |
378
+
| map-top-left-easting | Gamme d'entiers - **Les valeurs décimales ne sont pas prises en charge.**|
379
+
| map-top-left-northing | Gamme d'entiers - **Les valeurs décimales ne sont pas prises en charge.**|
380
+
| map-bottom-right-easting | Gamme d'entiers - **Les valeurs décimales ne sont pas prises en charge.**|
381
+
| map-bottom-right-northing | Gamme d'entiers - **Les valeurs décimales ne sont pas prises en charge.**|
382
+
| prefers-map-content | Valeurs discrètes de chaîne - les valeurs prises en charge incluent : `image`, `tile`, `feature`, `table`. Les préférences peuvent être définies via une multi-sélection dans [l'extension navigateur MapML](../extension/features#sélectionner-les-préférences-de-contenu-de-la-carte). |
383
+
| prefers-color-scheme | Valeurs discrètes de chaîne - les valeurs prises en charge sont `light` et `dark`. |
384
+
| prefers-lang | Code de langue à 2 caractères renvoyé par `navigator.language`, basé sur le paramètre de langue d'affichage du navigateur de l'utilisateur |
385
+
363
386
---
364
387
## Événements
365
388
@@ -619,7 +642,7 @@ let output = map.geojson2mapml(json);
// Formater la chaîne de requête média pour détecter les chevauchements :
697
+
// (xminm < xmaxq) et (xmaxm > xminq) et (yminm < ymaxq) et (ymaxm > yminq)
698
+
constquery=`(map-projection: OSMTILE) and (7 < map-zoom < 14) and (map-top-left-easting < ${bottomRightEasting}) and (map-bottom-right-easting > ${topLeftEasting}) and (map-bottom-right-northing < ${topLeftNorthing}) and (map-top-left-northing > ${bottomRightNorthing})`;
699
+
constmatcher=map.matchMedia(query);
700
+
// créer une couche pour représenter visuellement la requête lorsque la carte se déplace
701
+
constf=`<map-layer checked label="test media query"><map-meta name="projection" content="OSMTILE"></map-meta>
0 commit comments