GIS 4

Présentation et nouveautés

La version 4 de GIS abandonne la libraire Mapstraction au profit de Leaflet. Cette librairie permet de s’affranchir des librairies propriétaires tout en gardant les mêmes fonctionnalités, elle propose même de nouvelles fonctions.

Cette nouvelle version de GIS permet d’utiliser différents fonds de carte sans avoir à charger des scripts externes, seuls les scripts locaux de Leaflet et des plugins nécessaires sont chargés dans vos pages. À ce jour, le plugin propose plus de 25 couches de fond de carte différentes. La plupart de ces couches sont basées sur des données sous licence libre ou Creative Commons. Toutefois, si vous le souhaitez il est encore possible d’utiliser les couches de Google [1] ainsi que la couche satellite de Bing.

Voir la présentation de GIS au State of the Map France 2015.

La mise à jour n’entraîne pas de rupture de compatibilité majeure. Seuls quelques paramètres ont été supprimés du modèle qui gère l’affichage des cartes : control_zoom ; control_pan ; ajaxload.

Installation et configuration

Ce plugin nécessite le plugin Saisies.

Une fois installé, le plugin est configurable depuis le menu «Configurer > GIS» ou à l’adresse ecrire/?exec=configurer_gis :

Cette page permet de définir les options suivantes :

  • Coordonnées et zoom par défaut à utiliser dans les cartes ;
  • Couche de fond de carte affichée par défaut et listes des couches disponibles ;
  • Afficher les champs d’adresse dans les formulaires d’édition des points ;
  • Liste des objets associables à des points GIS.

Utilisation dans l’espace privé

Le plugin ajoute un bloc sur les pages des éléments de SPIP dans l’espace privé. Ce bloc se déplie au survol de la souris. Les liens situés en tête du bloc déplié permettent de basculer d’un panneau à une autre :

  • Points liés affiche la liste des points liés à l’objet en cours avec la possibilité de détacher ou supprimer chaque point ;
  • Rechercher un point affiche un formulaire pour rechercher un point existant et le lier à l’objet en cours ;
  • Lier un nouveau point affiche le formulaire d’édition de point pour en créer un nouveau et l’attacher à l’objet en cours .

Une page de gestion des points du site est accessible depuis le menu Édition > Points géolocalisés.

Depuis cette page, vous pouvez accéder à la fiche d’édition de chaque point afin d’en modifier les coordonnées, les champs d’adresse ou le logo.

Utilisation du modèle pour insérer des cartes dans vos pages

Pour insérer une carte dans un squelette, utilisez le modèle fourni par le plugin en insérant le code suivant à l’endroit où vous souhaitez afficher la carte :

  1. [(#INCLURE{fond=modeles/carte_gis,zoom=8,limit=100,scale=oui})]

Vous pouvez aussi utiliser le modèle fourni par le plugin pour afficher une carte depuis le contenu d’un article. Pour cela, il suffit d’ajouter ce code dans le texte de votre article :

<carte_gis1|zoom=8|limit=100|scale=oui>

Lire la documentation à propos des modèles sur spip.net.

Paramètres du modèle

paramètre valeurs
id_carte_gis / id_map id unique de la carte (à définir si plusieurs cartes sont affichées sur une même page)
lat = 48.3 latitude du centre de la carte
lon = -4.7 longitude du centre de la carte
zoom = 5 zoom de la carte
minZoom = 10 zoom minimum autorisé
maxZoom = 13 zoom maximum autorisé
default_layer = openmapsurfer nom de la couche affichée par défaut [2]
affiche_layers = openmapsurfer/opentopomap noms des couches proposées (séparés par des /)
sw_lat, sw_lon, ne_lat, ne_lon coordonnées des points de la bounding box à afficher
width = 100% largeur de la carte, 100% par défaut
height = 400px hauteur de la carte, 400px par défaut
style = non ne pas styler la carte
zoom_molette = non
zoom_wheel = non
désactiver le zoom avec la molette de la souris, actif par defaut
fullscreen = oui afficher un bouton pour passer la carte en plein écran
control_type = non ne pas afficher le contrôle de changement de couche
control_type_collapsed = non afficher le contrôle de changement de couche replié (oui par défaut)
no_control = oui
aucun_controle = oui
ne pas afficher les contrôles de la carte
scale = oui afficher l’échelle de la carte
overview = oui afficher une mini carte de situation
limit = 500 nombre max de marqueurs à afficher, 500 par défaut
objets = gis type d’objets à afficher (fichier json/gis_xx qui génère la source de données)
autocenterandzoom = oui
centrer_auto = oui
centrer et zoomer la carte automatiquement pour afficher tous les marqueurs
tooltip = oui afficher une bulle d’info contenant le titre du point lors de son survol
kml = 12 fichier KML à superposer à la carte (id_document ou URL / élément unique, tableau ou liste d’items séparés par une virgule)
gpx = 12 fichier GPX à superposer à la carte (id_document ou URL / élément unique, tableau ou liste d’items séparés par une virgule)
geojson = 12 fichier GeoJSON à superposer à la carte (id_document ou URL / élément unique, tableau ou liste d’items séparés par une virgule)
centrer_fichier = non permet de ne pas centrer la carte automatiquement sur les fichiers kml/gpx surperposés
localize_visitor = oui
localiser_visiteur = oui
centrer la carte sur la position du visiteur (API géolocalisation HTML5)
id_a_ouvrir id_gis de l’infobulle à afficher au chargement (marqueur uniquement)
point = non si elle vaut “non” cette option n’affichera pas de points du tout (utile pour n’afficher qu’un kml par exemple)
path_styles=#ARRAY{color,#fff} options de style des tracés issus de la couche GeoJSON (voir http://leafletjs.com/reference.html#path-options)
cluster = oui active le clustering
clusterMaxZoom = 11 regroupe les points jusque à ce zoom, mais pas au delà
maxClusterRadius = 80 rayon maximal (en pixels) qu’un cluster couvrira (80 par défaut)
clusterShowCoverageOnHover = oui Affiche au survol du cluster le contour de la zone couverte par les points regroupés
clusterSpiderfyOnMaxZoom = oui Active l’effet d’éclatement pour afficher les points qui se chevauchent
singleMarkerMode = oui Utilise les icones de cluster pour tous les points (même ceux qui ne sont pas dans un cluster)

Le paramètre objets

Ce paramètre vous permet de spécifier quel type d’objet vous souhaitez afficher sur la carte. Il peut prendre les valeurs suivantes : gis (valeur par défaut), articles, auteurs, documents, evenements, mots, rubriques, sites.

Si le paramètre “objets” vaut “articles”, vous pouvez utiliser en paramètre du modèle tous les critères utilisables sur une boucle ARTICLES.

D’un point de vue technique, le paramètre objets permet de définir quel squelette sera utilisé pour générer les données JSON qui alimenteront la carte. Lorsque le paramètre “objets” vaut “auteurs”, c’est le squelette plugins/gis/json/gis_auteurs.html qui est utilisé.

Avec l’option objets=point_libre, il est possible d’afficher une carte centrée sur un point non enregistré en base. Il faut alors indiquer la latitude et la longitude du point, ainsi que le zoom de la carte. On peut optionnellement donner un titre et une description à ce point, et définir une image pour le marqueur.

Exemple d’appel depuis le texte d’un article :

<carte_gis1|objets=point_libre|lat=48|lon=-5|zoom=10|titre=mon beau point|description=ma super description|icone=mon_image.png>

Depuis la version 4.8.10 il est possible d’afficher les points liés aux articles d’une branche (une rubrique et ses sous-rubriques) :

<carte_gis1|objets=articles_branche|id_rubrique=1>

Quelques exemples de cartes

Afficher les articles de la rubrique n°2 et superposer le KML correspondant au document n°2 :

[(#INCLURE{fond=modeles/carte_gis,
	objets=articles,
	id_rubrique=2,
	zoom=7,
	lat=48.214378965824345,
	lon=-4.543704986572266,
	kml=2})]

Afficher le ou les points liés à l’article n°2 et centrer la carte automatiquement pour afficher tous les points :

[(#INCLURE{fond=modeles/carte_gis,
	autocenterandzoom=oui,
	id_article=2})]

Afficher les points liés aux articles de l’auteur n°1 :

[(#INCLURE{fond=modeles/carte_gis,
	objets=articles,
	id_auteur=1,
	zoom=5})]

Afficher les auteurs du site :

[(#INCLURE{fond=modeles/carte_gis,
	objets=auteurs,
	zoom=5})]

Le modèle carte_gis_objet

Un second modèle existe pour un besoin plus précis : afficher toutes les informations géographiques liées à n’importe quel contenu de SPIP.

On lui donne donc au minimum les paramètres “objet” et “id_objet”, et le modèle n’affiche alors une carte que s’il y a au moins un point OU au moins un tracé (quelque soit le format, json, gpx, kml).

S’il y a plusieurs points, et plusieurs tracés, le modèle affiche tout ce qu’il arrive à trouver qui serait lié à l’objet demandé.

Pour plus de paramétrage, on peut continuer de passer les mêmes paramètres que pour le modèle par défaut “carte_gis”, car celui-ci est appelé par “carte_gis_objet”.

[(#REM) Exemple utilisant les paramètres propres au modèle + ceux du modèle classique ]
#INCLURE{fond=modeles/carte_gis_objet,
    id_carte_gis=evenement1234,
    objet=evenement,
    id_objet=1234,
    zoom_molette=non,
    fullscreen=oui,
    centrer_auto=oui}

Boucles et balises

Voici la liste des balises disponibles dans une boucle GIS : #ID_GIS, #TITRE, #DESCRIPTIF, #LAT, #LON, #ZOOM.

Et si vous avez activé le geocoder ou que vous avez rempli les champs d’adresse à la main : #ADRESSE, #PAYS, #CODE_PAYS, #REGION, #VILLE, #CODE_POSTAL.

Critère gis

Le critère {gis} permet de forcer une jointure sur la table GIS dans les boucles des autres objets. Ainsi, une boucle ARTICLES qui comporte le critère {gis}, affichera uniquement les articles attachés à un point (un article par point uniquement).

Les informations de ce point pourront être affichées avec les balises suivantes : #TITRE_GIS et #DESCRIPTIF_GIS, #ADRESSE_GIS, #PAYS_GIS, #CODE_PAYS_GIS, #REGION_GIS, #VILLE_GIS, #CODE_POSTAL_GIS.

Remarque : les balises sont suffixées afin d’éviter tout problème de champ homonyme avec un autre plugin.

<BOUCLE_gis(ARTICLES){gis}{id_rubrique ?}>
#ID_GIS - #LAT - #LON - #ZOOM <br/>
Titre de l'article : #TITRE <br />
Descriptif de l'article : #DESCRIPTIF <br />
Titre du point : #TITRE_GIS <br />
Descriptif du point : #DESCRIPTIF_GIS <br />
</BOUCLE_gis>

Critère distance

Le critère {gis distance<XX} permet de filtrer les résultats d’une boucle GIS en fonction de la distance (en kilomètres) par rapport au point présent dans l’environnement.

Par exemple, pour lister les points situés à moins de 50 kilomètres du point numéro 1 :

<BOUCLE_m(GIS){id_gis=1}>
<p>#TITRE / #LAT / #LON</p>
<BOUCLE_b(GIS){gis distance<50}>
<p>#ID_GIS / #TITRE / #DISTANCE km</p>
</BOUCLE_b>
</BOUCLE_m>

Critère distancefrom

Le critère {distancefrom} peut être utilisé soit lorsque le critère gis est présent sur un objet, ou lorsqu’on est déjà sur une boucle GIS.

Le critère ne sélectionne que les objets qui ont une localisation (un point lié) en respectant une certaine distance à un autre point qu’on donne en paramètre. Ce point peut être soit un tableau avec “lat” et “lon”, soit un id_gis.

Par exemple, pour trouver tous les articles dans un rayon de la variable “distance” autour d’un point donné :

<BOUCLE_c(ARTICLES){gis}{distancefrom #ARRAY{lat,#ENV{lat},lon,#ENV{lon}}, <=, #ENV{distance}}>
<p>#ID_GIS / #TITRE / #DISTANCE km</p>
</BOUCLE_c>

Formulaire d’édition de point

Le formulaire #FORMULAIRE_EDITER_GIS permet de créer ou modifier un point. Vous pouvez l’utiliser dans vos squelettes en respectant la syntaxe suivante :

#FORMULAIRE_EDITER_GIS{id_gis, objet, id_objet, retour}

Définition des paramètres du formulaire :

  • id_gis : identifiant numérique du point ou vide pour créer un nouveau point
  • objet : le type d’objet auquel est attaché le point
  • id_objet : id_objet de l’objet auquel est attaché le point
  • retour : url de retour vers laquelle le formulaire redirigera après validation

Par exemple, voici un extrait de code qui permet de modifier le point attaché à un article ou d’en créer un nouveau s’il n’y en a pas déjà un attaché à l’article.

<BOUCLE_unpoint(GIS){id_article}{0,1}>
#SET{id_gis,#ID_GIS}
</BOUCLE_unpoint>
#SET{id_gis,nouveau}
<//B_unpoint>
#FORMULAIRE_EDITER_GIS{#GET{id_gis},'article',#ID_ARTICLE,#URL_ARTICLE}

Personnalisation

Icône par défaut des marqueurs

Il est possible de définir une icône par défaut pour les marqueurs des cartes. Pour cela, il suffit de déposer l’image de votre icône personnalisée dans votre dossier squelettes :
squelettes/images/marker_defaut.png

Si vous le souhaitez, vous pouvez associer une image d’ombre à votre icône personnalisée toujours dans votre dossier squelettes : squelettes/images/marker_defaut_shadow.png

Personnaliser le contenu des infobulles

Le contenu des infobulles est généré à partir des attributs title et description de chaque item retourné par les squelettes JSON. Vous pouvez surcharger les squelettes du répertoires gis/json afin de personnaliser le contenu des infobulles.

Afin de simplifier ces personnalisations, il est plus simple de passer par un #INCLURE comme expliqué dans l’article Gis 4 Surcharger les infobulles.

Étendre la liste des paramètres du modèle carte_gis

Si vous utilisez des fichiers gis/json personnalisés il peut arriver que vous souhaitiez leur transmettre des paramètres avec des noms de votre choix. Par défaut, le plugin GIS autorise la liste de noms suivante :

  • toutes les clés primaires déclarées et connues
  • ainsi que ces variables : id_objet, id_secteur, id_parent, media, recherche, mots, pays, code_pays, region, ville, code_postal, adresse

Cette liste peut être enrichie en utilisant le pipeline gis_modele_parametres_autorises.

Exemple d’utilisation depuis un fichier mes_options.php :

$GLOBALS['spip_pipeline']['gis_modele_parametres_autorises'] .= "|nom_de_la_fonction";
 
function nom_de_la_fonction($flux) {
	$flux[] = 'machin';
	$flux[] = 'bidule';
	return $flux;
}

Astuces et usages avancés

Vous pouvez consulter et partager vos astuces pour GIS sur cette page du carnet.

Footnotes

[1Dans ce cas le plugin ajoutera les appels vers les scripts de Google dans vos pages afin de respecter les conditions d’utilisation restrictives de ce fournisseur.

[2Liste des noms de couches disponibles : openstreetmap_mapnik, openstreetmap_blackandwhite, openstreetmap_de, openstreetmap_hot, bing_aerial, openmapsurfer... Voir la liste complète en ligne

updated on 28 April 2020

Discussion

416 discussions

  • 4

    j’ai une erreur à l’utilisation.
    -  la carte s’affiche correctement (de manière standard)
    -  mon navigateur détecte une erreur 404 à l’appel de https://monsite.com/leaflet-src.js.map
    -  je n’ai pas possibilité d’afficher d’autres fonds de carte
    -  sur la page de configuration du plugin, dans “désactiver certains plugins”, il y a “kml.js, gpx.js, topojson.js, control.Fullscreen.js, control.minimap.js, leaflet.marketcluster-src.js”, sans possibilité de retirer quoi que ce soit. Je suppose que c’est le problème
    Une idée ?

    spip 3.2.7 mutualisé; GIS 4.48

    • Salut,

      mon navigateur détecte une erreur 404 à l’appel de https://monsite.com/leaflet-src.js.map

      Je crois avoir déjà vu ça, mais je ne le reproduis pas...

      Pour le reste, comme toujours, un lien vers la page en question nous permettra de t’aider, sans ça ton message est un appel dans le vide :p

    • visible ici (+config plugin):
      https://www.olivier-testa.com/-expeditions-.html
      Il me semble que les scripts ne sont pas trouvés (path?)

    • bonjour, une idée ou un point de départ pour comprendre? faudrait-il réinitialiser quelque chose?
      merci!

    • Hop, tentons de répondre à toutes les questions :

      > mon navigateur détecte une erreur 404 à l’appel de https://monsite.com/leaflet-src.js.map

      Mon firefox ne m’indique aucune 404 sur ta page, sauf une à propos d’une image de ton site cf https://www.olivier-testa.com/sites/olivier-testa.com/squelettes/css/fond-ligne-niveau.png

      > je n’ai pas possibilité d’afficher d’autres fonds de carte

      Tu as modifié la valeur de la couche par défaut dans la configuration du plugin ? Tu as essayé d’en sélectionner plusieurs dans le bloc “couches proposées” ?

      > sur la page de configuration du plugin, dans « désactiver certains plugins », il y a « kml.js, gpx.js, topojson.js, control.Fullscreen.js, control.minimap.js, leaflet.marketcluster-src.js », sans possibilité de retirer quoi que ce soit. Je suppose que c’est le problème

      Cette option avancé permet d’indiquer à GIS de ne pas insérer certains scripts (et donc de désactiver certaines fonctionnalités), tu peux laisser tout activé par défaut sans t’en préoccuper.

      Hésite pas à passer sur irc.spip.net si tu veux qu’on en discute.

    Reply to this message

  • Bonjour
    Question syntaxe kml : je veux associer une url à la zone géographique spécifiée dans mon fichier kml. Autrement dit, rendre cette zone cliquable. Voir page
    Merci !

    Reply to this message

  • 1

    Bonjour,
    Je me permet de reposer une question, j’essaye de voir où je peux aller avec ce super plugin

    Je souhaite afficher dans un article une carte des points géolocalisés des évènements liés à cet article.
    J’ai mis :
    [(#INCLUREfond=modeles/carte_gis,objets=evenements,id_article,)]
    OK, cela fonctionne
    Cerise sur la gâteau, ...chacun des évènements est lié à un mot-clé (lui même lié à une couleur)...

    Serait-il possible qu’en fonction du mot-clé, lié à l’évènement, il y ait un marqueur différent?
    Je sais c’est un super cerise.
    Merci d’avance pour votre lecture

    • Je me répond à moi même et pour ceux que cela peut aider.
      Je me suis inspirer de cet article pour l’adapter aux évènements.

      • J’ai donc créé un fichier gis_evenements_logomot.html (en partant du fichier gis_evenements.html proposé dans le plugin GIS4 (dossier json)

      Ce fichier comporte le code suivant

      <BOUCLE_events(EVENEMENTS){gis}{id_evenement ?}{id_article ?}{id_rubrique ?}{id_secteur ?}{id_mot ?}{id_auteur ?}{recherche ?}{0, #ENV{limit}}{","}>
      		{"type": "Feature",
      		["geometry": (#GEOMETRY|appliquer_filtre{wkt_to_json}|sinon{{"type": "Point", "coordinates": \[#LON, #LAT\]}}),]
      		"id":"#ID_GIS",
      		"properties": {
      			"title":[(#URL_EVENEMENT|extraire_multi|lien_ou_expose{[(#TITRE_GIS*|sinon{#TITRE*}|supprimer_numero)]}|json_encode)],
      			"description":[(#DESCRIPTIF_GIS|sinon{#DESCRIPTIF}|json_encode)]
      			<BOUCLE_logomot(MOTS){id_evenement}{type={{echelon_de_evenement}}}>
      			[(#LOGO_MOT_NORMAL|gis_icon_properties)]
      			</BOUCLE_logomot>[,
      			"styles": (#GEOMETRY_STYLES|appliquer_filtre{geometry_styles_to_json})]
      		}}</BOUCLE_events>

      où echelon_de_evenement correspond au nom du groupe de mon groupe de mot clé.

      • Je dépose ce fichier dans le dossier un dossier /json de mon dossier /squelettes
      • Chaque mot-clé à pour logo un marqueur spécifique (à vous de choisir)
      • Enfin l’intégration de ma carte GIS prend alors pour objet : evenements_logomot,

      Pour ma part cela donne cela : [(#INCLUREfond=modeles/carte_gis, objets=evenements_logomot,id_article)]

    Reply to this message

  • 2

    Bonjour,

    À l’instar des illustrations qui possèdent leur numéro d’identifiant au bas de chaque article, ne pourrait-on pas ajouter le numéro des points GIS liés à un article ? Ceci permet de savoir rapidement quel est le numéro du point que l’on veut insérer dans un article via un modèle, par exemple.

    Merci,
    françois

    Reply to this message

  • 2

    Bonjour,
    J’ai un soucis qui doit être tout bête mais je bloque.
    Dans la page article.html, j’appelle la carte GIS mais je souhaite qu’elle n’apparaisse pas s’il n’y a pas de point associé...
    Pour l’instant, j’ai un tout simple

    [(#INCLURE{fond=modeles/carte_gis,objets=articles,id_article,height=400px,zoom=10,autocenterandzoom=oui,fullscreen = oui})]

    Mais la carte s’affiche sans point... je souhaiterai que dans un tel cas, la carte ne s’affiche pas...
    Merci d’avance

    • Bonjour,

      Tu peux entourer ton code avec une boucle comme :

      <BOUCLE_gis0(GIS){id_article}{0,1}>
      ..
      </BOUCLE_gis0>
    • Super, merci pour le coup de main

    Reply to this message

  • 4

    Bonjour,

    J’ai plusieurs points GIS dont certains ne sont associés à aucun objets SPIP.

    Dans le corps de texte d’un article, en ajoutant le modèle standard :

    <carte_gis|autocenterandzoom=oui>

    la carte affiche tous les points, associés ou pas à un article : parfait.

    En personnalisant le fichier ./json/gis.html pour y ajouter (par exemple) :

    "description":[(#ID_ARTICLE|json_encode)]

    la carte n’affiche que les points associés à un article.

    Mon besoin étant d’afficher tous les points et #ID_ARTICLE (c’est un exemple) dans l’infobulle quand le point est associé à un article ou rien quand il n’est pas associé.

    Merci pour vos expériences et lumières,
    françois

    • Ha oui, fort possible que la présence de la balise id_article dans la boucle force une jointure sur les articles. Essaye peut-être avec la balise id_objet, sinon pourquoi ne pas utiliser le squelette json_gis_articles.html puisque tu souhaites afficher des données issues d’articles ?

    • En fait non, je ne « souhaites pas afficher des données issues d’articles ».

      Comme indiqué, je souhaite afficher tous les points, associés ou pas, et mon JSON ne retourne que les points associés quand j’ajoute #ID_ARTICLE. Je pense effectivement qu’il y a une jointure qui se promène.

      Ma question est bien : comment retourner tous les points et pour les points associés à un article afficher #ID_ARTICLE ?

      Merci !

    • As-tu testé ma proposition ?

    • Oui b_b, mais rien de mieux.

      J’ai utilisé la solution suivante : dans le JSON, je renseigne une variable dans la BOUCLE avant le formatage des données json :

      <BOUCLE_gis(GIS){id_gis ?}{objet ?}{id_objet ?}{id_rubrique ?}{id_article ?}{id_breve ?}{id_document ?}{id_mot ?}{id_auteur ?}{id_syndic ?}{recherche ?}{0, #ENV{limit}}{","}>
      #SET{s0,''}
      <BOUCLE_(ARTICLES){id_gis}>#SET{s0,#URL_ARTICLE}</BOUCLE_>
      {"type": "Feature",
      ["geometry": (#GEOMETRY|appliquer_filtre{wkt_to_json}|sinon{{"type": "Point", "coordinates": \[#LON, #LAT\]}}),]
      "id":"#ID_GIS",
      "properties": {
      	"title":[(#TITRE*|extraire_multi|supprimer_numero|json_encode)],
      	"description":[(#VAL{
      		[<p>(#DESCRIPTIF|textebrut)</p>]
      		<p>[(#ADRESSE|textebrut)<br />][(#CODE_POSTAL)&nbsp;]#VILLE</p>
      		[<a href='(#GET{s0})'>Plus d'informations</a>]
      		}|json_encode)][
      	(#LOGO_GIS|gis_icon_properties)][,
      	"styles": (#GEOMETRY_STYLES|appliquer_filtre{geometry_styles_to_json})]
      }}</BOUCLE_gis>

      et je peux ainsi afficher tous les points; ceux qui ont des articles associés ont un lien vers l’article et pas les autres.

      Merci pour tes propositions.
      françois

    Reply to this message

  • 1

    Bonjour,
    Merci pour cet excellent plugin. Pour la personnalisation du logo d’un point géolocalisé, pourrais-tu lui faire bénéficier du plugin rôle de document ?

    • Pour l’instant non, pas dans le plugin par défaut, mais peut-être plus tard quand on aura pleinement intégré la notion de rôles des docs/logos dans le core (cf le chantier en cours du passage des logos en tant que documents). Mais rien ne t’empêche de personnaliser les squelettes json du plugin pour le faire sur ton site :)

    Reply to this message

  • 14

    Bonjour et merci du boulot !

    J’ai mis sur mage sommaire le code suivant

    [(#INCLURE{fond=modeles/carte_gis,
    	objets=articles,
    	id_rubrique=1,
    	zoom=2,
    	fullscreen=oui,
    	lat=48.214378965824345,
    	lon=-4.543704986572266,
    	kml=2})]

    Nickel, je voulais changer ce qui apparaît dans l’infobulle et j’ai copié le fichier plugins/gis/json/gis_articles.html dans squelettes/json/gis_articles.html comme indiqué dans l’article.

    Mes modifs ne sont pas prises en compte (même avec vidage de cache / recalcul de page). Le plus étonnant est que j’ai même supprimé plugins/gis/json/gis_article.html et squelettes/json/gis_articles.html et que la carte apparaît toujours...

    J’ai retenté un paquet de fois pour être sûr que je faisais pas de bourde, mais à priori, non.

    Une piste ? (PS : V4.47.18)
    Bonne journée !

    • Une piste ?

      oui, gis_article.html != gis_articles.html :)

      Une url ?

    • Merci de la réponse, c’est bien gis_articles.html que j’ai utilisé que j’ai fait (coquille corrigée).

      La coquille vient de l’article (j’ai fait un copier / coller)

      Voici l’url : https://www.naga44.org/test/

    • Merci de la réponse, c’était une coquille (provenant de l’article , j’ai fais un copier / coller)
      J’ai bien utilisé gis_articles.html. Malheureusement, ça vient pas de là ;)

      Voici l’url : https://www.naga44.org/test/

    • Je n’accède pas à ton squelette perso https://www.naga44.org/test/squelettes/json/gis_articles.html c’est normal ?

    • Oups, désolé, j’avais tout retiré, vu que ça ne prenait pas.
      Je viens de reupload https://www.naga44.org/test/squelettes/json/gis_articles.html avec la même modif que dans l’article.

      [(#SET{titre,<a href="#URL_ARTICLE">#TITRE*</a>})]"title":[(#GET{titre}|json_encode)],
    • Pardon, j’avais effacé, vu que ça prenait pas. C’est reuploadé, avec la même modif que dans l’article

      [(#SET{titre,<a href="#URL_ARTICLE">#TITRE*</a>})]"title":[(#GET{titre}|json_encode)],
    • Et bien j’ai le plaisir de t’annoncer (au bout de X messages) que ça fonctionne bien :

      https://www.naga44.org/test/spip.php?page=gis_json&id_rubrique=1&objets=articles&limit=500

      Le json contient bien ce que tu lui demandes de généré, cad un titre avec un lien vers l’article, et c’est visible sur ta carte (d’ailleurs c’était visible depuis mon premier message).

    • Bonjour,
      désolé b_b, je n’ai que trois messages qui sont passés (ceux visibles ici).
      J’espère que tu n’as pas eu de doublons, j’ai fait d’autres envois, mais j’ai eu des déconnexions et ce que j’essayais d’envoyer n’était pas posté (en tout cas, moi je ne voyais rien…)

      Bref, désolé si ça a été un souci, c’est déjà adorable de prendre du temps pour me répondre, j’ai pas envie que ce soit une corvée...

      Pour clarifier :
      Je sais que le lien est visible, c’est ce que j’ai depuis le début, sans aucune modification de gis_articles.html, ni ajout de gis_articles.html dans squelettes/json/, juste l’INCLURE dans l’article. C’est pourquoi, je ne comprenais pas trop le but de la modif présentée dans l’article.

      Si je supprime gis_articles.html (de plugins/gis/json/ et de squelettes/json/), la carte est la même. Pourtant, pourquoi serait elle visible alors ?

      Si dans squelettes/json/ gis_articles.html j’enlève le titre :

      [(#SET{titre,<a href="#URL_ARTICLE">#TITRE*</a>})]"title":[(#GET{titre}|json_encode)],

      et ne garde que :

      	"properties": {
      			"description":[(#DESCRIPTIF_GIS|sinon{#DESCRIPTIF}|json_encode)][
      			(#LOGO_GIS|gis_icon_properties)][,
      			"styles": (#GEOMETRY_STYLES|appliquer_filtre{geometry_styles_to_json})]

      La carte est toujours la même avec le titre. D’ailleurs actuellement, j’ai enlevé le titre et sur https://www.naga44.org/test/spip.php?page=gis_json&id_rubrique=1&objets=articles&limit=500 il y a toujours les liens vers les titres… (page recalculée, cache vidé)

      Merci du temps que tu m’as consacré. Désolé encore, si il y a quelque chose d’évident à coté duquel je passe.

    • Reprenons, par défaut les infobulles n’affichent que le titre de l’objet sans lien si on affiche les points et non les articles, cf https://git.spip.net/spip-contrib-extensions/gis/src/branch/master/json/gis.html#L6 et exemple ici https://labo.eliaz.fr/spip.php?page=carte

      Quand on affiche des articles, le code a changé depuis la rédaction de cette documentation cf https://git.spip.net/spip-contrib-extensions/gis/commit/355aa4f60412e2efd9584eb230b1650ee47cd791 on affiche bien le titre avec un lien cf https://git.spip.net/spip-contrib-extensions/gis/src/branch/master/json/gis_articles.html#L6

      C’est certainement ça qui t’as mis sur une mauvaise piste, je pense qu’il faut mettre à jour la doc et renvoyer vers l’article dédié à ce sujet https://contrib.spip.net/Gis-4-Surcharger-les-infobulles

    • Merci pour ta réponse, je vais regarder du coté de https://contrib.spip.net/Gis-4-Surcharger-les-infobulles.
      Mais j’avoue ne pas comprendre pourquoi en effaçant le titre, il est toujours visible sur le site. Pour moi, cela montre que le fichier n’est pas pris en compte. me trompe-je ?
      Je viens même de faire un vidage de cache manuel (au cas où), mais non, le titre apparaît alors qu’il est effacé...

    • Mais j’avoue ne pas comprendre pourquoi en effaçant le titre, il est toujours visible sur le site.

      Le var mode debug ou inclure te le dira :p

      PS : j’ai mis la doc à jour.

    • Un grand merci, c’est trouvé !
      Je ne connaissais pas le mode inclure (debug ne donnait rien).
      En fait c’est “modeles/carte_gis.html” qui est appelée et non pas “gis_articles.html” comme indiqué dans l’article.
      Le mode inclure va m’être tellement utile, ne découvrir cela que maintenant... Mieux vaut tard que jamais !
      Merci mile fois de ta patience et de ton temps.

    • En fait c’est « modeles/carte_gis.html » qui est appelée et non pas « gis_articles.html » comme indiqué dans l’article.

      Non non, l’article est bon sur ce point, je te l’assure :)

    • C’est moi qui me suis planté alors. Étant donné que j’ai fond=modeles/carte_gis dans INCLURE, ça me parait normal que carte_gis.html soit appelé.

      J’avais repris l’exemple de l’article

      [(#INCLURE{fond=modeles/carte_gis,
      ...

      et j’ai dû mal comprendre un truc par la suite, mais vu que le reste n’est plus présent dans l’article, je ne sais pas quoi ;)

    Reply to this message

  • 2

    Bonsoir,

    Je viens d’installer GIS4 -47-18 sur mon site de test qui utilise la dernière version de SPIP 3-2-7.

    Lorsque j’essaye de créer un point j’ai l’erreur suivante :
    Erreur SQL 1146
    Table ’campingmrb2411.spip31_gis’ doesn’t exist
    SELECT gis.id_gis, 0 as points FROM spip_gis AS `gis`

    Vous auriez une idée du problème ?
    Merci
    Patrick

    • Salut, certainement un problème lors de la création des tables, essaye d’utiliser la réparation des tables de la base depuis la page de maintenance de SPIP. Sinon, désinstalle et réinstalle le plugin.

    • oui tout à fait

      Merci à vous

      Patrick

    Reply to this message

  • 2

    Bonjour,

    un point pas très clair pour moi.

    Lorsqu’on créé un point, et si on a activé la config, il est possible de chercher une adresse.

    J’imagine que la recherche dans la base d’adresse vient d’une base de donnée externe. En l’occurence, je suppose OpenStreetMap (car c’est la couche qu’on charge par défaut)?

    Ma question est la suivante : y-a-t-il un délai entre la modification d’une carte sur le site officiel “openstreetmap” pour ajouter une adresse, et le moment où on peut trouver l’adresse dans le formulaire ?

    J’ai fait une modif il y a plus de 24 h sur le site d’OSM, et je n’arrive toujours pas à trouver automatiquement l’adresse.

    • Salut, le geocoder utilise par défaut l’API de photon (celle de nominatim est aussi dispo en option), je n’ai pas d’idée du temps nécessaire à la répercution d’une modif dans la base OSM vers l’API en question, mais je pense que le délai doit bien dépasser 24h. Tu trouveras certainement une réponse plus détaillé du côté de la communauté OSM.

    • ok, merci

      j’irais voir vers eux lorsque je reprendrais le dossier

    Reply to this message

Ajouter un commentaire

Who are you?
[Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom