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 :
[(#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è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 |
autocenter = oui centrer = oui |
centrer la carte automatiquement pour afficher tous les marqueurs (sans modifier le zoom) |
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;
}
API de cartes statiques
Depuis la version 4.53.0 il est possible de générer des cartes statiques sous forme d’images à l’aide du filtre |gis_static_map
.
Par exemple, le code suivant :
<BOUCLE_centrer(GIS){id_gis=1}>
[(#ID_GIS|gis_static_map{335,170,openstreetmap_fr,7})]
</BOUCLE_centrer>
Génère l’image d’une carte de 335 pixels de large et 170 de haut, centrée sur les coordonnées du point n° 1, avec pour fond de carte la couche openstreetmap_fr et un niveau de zoom à 7.
Détails des arguments du filtre :
gis_static_map{ID,largeur,hauteur,id_fond_carte,zoom,markers,latitude,longitude}
- ID : ID du point à afficher
- largeur : largeur de l’image
- hauteur : hauteur de l’image
- id_fond_carte : le nom de la couche à utiliser en fond de carte
- zoom : le zoom de la carte
- markers : les informations des markers à afficher sous la forme suivante
lat;lon;url|lat;lon;url
- latitude : la latitude du centre de la carte
- longitude : la longitude du centre de la carte
Exemples d’usage avancés :
[(#REM|gis_static_map{335,170,openstreetmap_de,7,48.33;-4.76;https://www.vertlejardin.fr/plugins/vertlejardin/images/marker_defaut.png})]
Génère une carte avec une image de marker personnalisée dont le centre est défini à l’aide des paramètres latitude & longitude du filtre (sans utiliser l’identifiant d’un point GIS).
#SET{markers,#ARRAY}
<BOUCLE_articles2(ARTICLES){gis}{id_article=1}
>#SET{markers,#GET{markers}|push{#LAT;#LON;http://open.mapquestapi.com/staticmap/geticon?uri=pcenter.png}}</BOUCLE_articles2>
[(#REM|gis_static_map{335,170,openstreetmap_mapnik,'',#GET{markers}|implode{'|'}})]
Génère une carte affichant tous les points liés à l’article n° 1 en utilisant une image de marker personnalisée.
Liste des fonds de carte utilisables avec l’API et aperçu du rendu :
openstreetmap_mapnik,
openstreetmap_de,
openstreetmap_fr,
openstreetmap_hot,
opentopomap,
stamen_toner,
stamen_tonerlite,
stamen_terrain,
stamen_watercolor,
esri_worldstreetmap,
esri_delorme,
esri_worldtopomap,
esri_worldimagery,
esri_worldterrain,
esri_worldshadedrelief,
esri_worldphysical,
esri_oceanbasemap,
esri_natgeoworldmap,
esri_worldgraycanvas,
cartodb_positron,
cartodb_positron_base,
cartodb_darkmatter,
cartodb_darkmatter_base,
cartodb_voyager,
cartodb_voyager_base
Astuces et usages avancés
Vous pouvez consulter et partager vos astuces pour GIS sur cette page du carnet.
Discussions par date d’activité
473 discussions
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 !
Répondre à ce message
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.
Ce fichier comporte le code suivant
où echelon_de_evenement correspond au nom du groupe de mon groupe de mot clé.
Pour ma part cela donne cela : [(#INCLUREfond=modeles/carte_gis, objets=evenements_logomot,id_article)]
Répondre à ce message
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
Bonne idée, c’est intégré par https://zone.spip.net/trac/spip-zone/changeset/124518 ça sera bientôt dispo en zip.
Super !
Merci beaucoup b_b ;-)
Répondre à ce message
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
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 :
Super, merci pour le coup de main
Répondre à ce message
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 :
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) :
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 :
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
Répondre à ce message
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 :)
Répondre à ce message
Bonjour et merci du boulot !
J’ai mis sur ma page sommaire le code suivant
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 !
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.
Pardon, j’avais effacé, vu que ça prenait pas. C’est reuploadé, avec la même modif que dans l’article
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 :
et ne garde que :
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é...
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.
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
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 ;)
Répondre à ce message
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
Répondre à ce message
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
Répondre à ce message
Bonjour,
J’ai toujours eu une exploitation ’simple’ de ce super plugin de géoloc, et là je sèche :
Comment faire pour qu’au passage de la souris l’infobulle s’affiche ET que je puisse cliquer dessus pour m’envoyer sur une ancre dans la page ?
Si je vois bien l’infobulle, impossible de fabriquer le clic.
Quelqu’un a-t-il déjà eu à faire à ce comportement du plugin ?
Merci
Nico
Bonjour,
Tu as regardé https://contrib.spip.net/Gis-4-Surcharger-les-infobulles ? En mettant un lien dedans ?
Répondre à ce message
Ajouter un commentaire
Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :
Merci d’avance pour les personnes qui vous aideront !
Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.
Suivre les commentaires : |