Fonds vector-tile serveur geoservice
Cette section à pour but de montrer quelques exemples d'utilisation des fonds de plan tuilé vectorielles a partir du serveur geoservice:
- Utiliser votre login / mot de pass afin de renseigner les informations du token
- D'autres moyens de remplir un token sont disponibles dans l'application, voir la doc API
- Ajouter une source de token pour l'application utilisable par différents calques
- actuellement uniquement les types suivants:
- vectorTile
- actuellement uniquement les types suivants:
- En commentaire "comment ajouter une source de token directement sur le calque"
Démo
{
"jsLib": [
"https://karteis.sct.saas-gfi.eu/dist/mapviewer/latest/karteis-mapviewer-var.js"
]
}
<!-- Ne pas utiliser dans votre code -->
<!-- La déclaration du css n'est utile que pour l'affichage sur le site d'exemples -->
<link rel="stylesheet" href="/mapviewer/mapviewer.css">
<!-- Ne pas utiliser dans votre code -->
<!-- Dans nos exemple on utilise font-awesome pour afficher les icones de boutons -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
<form id="formbackground" >
<input name="username" placeholder="username" autocomplete="current-username"/>
<input name="password" placeholder="password" type="password" autocomplete="current-password"/>
<button>+ Fond de plan tuilé protégé</button>
</form>
<!-- Le div qui sera utilisé pour injecter la carte -->
<div id="kmap" style="height:375px;" />
const form = document.getElementById("formbackground");
form.addEventListener("submit", addProtectedBackgrounds);
// Initialisation de la carte avec ses plugins
const kmapvInstance = (new kmapv.Mapviewer({
mapdiv: document.getElementById('kmap'), // Il est aussi possible d'utiliser directement l'id du div contenant la carte
projection: 'EPSG:3857',
defaultCenter: [250000,5950000],
defaultZoom: 6,
minZoom: 5,
maxZoom: 22,
}))
.use(kmapv.CommonLayer({})) // charge le plugin générique des calques
.use(kmapv.BackgroundLayer({})) // charge le plugin de prise en charge des fond de plans
//.use(kmapv.DataLayer({})) // chage le plugin de prise en charge des couche de données
// ajout du layermanager :
kmapvInstance.horizontalToolbar.addLayerManagerTool({
reordering: false // on ne veut pas réorganiser les calques
})
// création de groupe
kmapvInstance.commonLayer.addGroup("FondDePlan",{
title: "Fonds de plan",
zIndex: 0
})
// Ajout du fond de plan OSM
kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-osm', // identifiant
'osm', // type
{
idGroup: "FondDePlan", // groupe ou ajouter le calque
title: 'OSM', // libellé
zIndex: 0, // z-order
visible: true,
baseLayer: false // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
})
/** methode asynchrone car on veut attendre pour chaque plan qu'il soit ajouter dans le pool de token */
async function addProtectedBackgrounds(e) {
// empêche de recharger
e.stopPropagation();
e.preventDefault();
// converti le formulaire en objet {username, password}
const formData = new FormData(e.target);
const auth = Object.fromEntries([...formData.entries()])
// ajoute une source de jeton pour les outils mapviewer (on attend qu'elle soit initilisée car ici on sait que la méthode "url" attend un retour de jeton)
await kmapvInstance.addTokenSource({
id:"geoservice",
type: 'url',
method:'get',
url:'https://services.geosphere.fr/api/auth/login?key=f5e7d976d664ce8aa154bc210375db8e621b06cff732895e5d3275a3c7cf4379',
auth,
tokenKey:'jwt',
refreshInterval: 10000
})
// la source du token peut aussi être entièrement configurée sur le layer
/*await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-osm-basic', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'OSM basic', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/osm-basic/style.json',
params: {
token: {
id:"geoservice",
type: 'url',
method:'get',
url:'https://services.geosphere.fr/api/auth/login?key=f5e7d976d664ce8aa154bc210375db8e621b06cff732895e5d3275a3c7cf4379',
auth,
tokenKey:'jwt',
refreshInterval: 10000
}
}
})*/
await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-osm-basic', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'OSM basic', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/osm-basic/style.json',
params: {
token: {
id:"geoservice",
/*type: 'url',
method:'get',
url:'https://services.geosphere.fr/api/auth/login?key=f5e7d976d664ce8aa154bc210375db8e621b06cff732895e5d3275a3c7cf4379',
auth,
tokenKey:'jwt',
refreshInterval: 10000*/
}
}
})
await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-osm-openmaptiles', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'OSM Openmaptiles ', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/osm-openmaptiles/style.json',
params: {
token: {
id:"geoservice",
}
}
})
await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-osm-bright', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'OSM bright', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/osm-bright/style.json',
params: {
token: {
id:"geoservice",
}
}
})
await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-cadastre', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'cadastre', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/cadastre/style.json',
params: {
token: {
id:"geoservice",
}
}
})
await kmapvInstance.backgroundLayer.addBackgroundLayer(
'background-batiments', // identifiant
'vectorTile', // type
{
idGroup: 'FondDePlan', // groupe ou ajouter le calque
title: 'batiment', // libellé
zIndex: 1, // z-order
visible: false,
baseLayer: true, // les calques avec baseLayer = true dans un même groupe s'affiche avec un radiobutton (un seul a la fois)
styleUrl: 'https://services.geosphere.fr/maps/tiles/styles/batiments/style.json',
params: {
token: {
id:"geoservice",
}
}
})
}
kmapvInstance.commonLayer.getLayers().forEach((layer) => {
layer.on("change:visible",(evt) => {
console.log(kmapvInstance.getMap().getView().getZoom(),kmapvInstance.getMap().getView().getCenter())
console.log("Evenement",evt)
console.log("LayerId",evt.target.get(kmapvInstance.commonLayer.propertiesName.ID_LAYER))
console.log("Visibilité",evt.target.get(evt.key))
})
})
