diff --git a/content/articles/2024/2024-12-24_QGIS-Layers-Menu-From-Project-Le-catalogue-magique.md b/content/articles/2024/2024-12-24_QGIS-Layers-Menu-From-Project-Le-catalogue-magique.md new file mode 100644 index 0000000000..b2a87e8a33 --- /dev/null +++ b/content/articles/2024/2024-12-24_QGIS-Layers-Menu-From-Project-Le-catalogue-magique.md @@ -0,0 +1,158 @@ +--- +title: "LMFP : LE catalogue magique !" +subtitle: Deux voix, une magie +authors: + - Emilie BIGORNE + - Céline PORNIN +categories: + - article +comments: true +date: 2024-12-24 +description: "Une extension QGIS peut-être (trop) méconnue : Layers Menu From Project permet de simplifier la vie des administrateurs ET des utilisateurs, retour d'expérience à deux voix. " + +icon: fontawesome/solid/wand-magic-sparkles +image: https://cdn.geotribu.fr/img/articles-blog-rdp/articles/2024/retex_layers_menu_from_project/be-qool_myriade.png +license: default +robots: index, follow +tags: + - Layers Menu From Project + - plugin QGIS + - QGIS +--- + +# Plugin Layers Menu From Project : LE catalogue magique ! + +:calendar: Date de publication initiale : {{ page.meta.date | date_localized }} + +Bonjour à toi lectrice ou lecteur ! + +Aujourd'hui, à deux voix, nous avons choisi de faire un retour d'expérience sur l'utilisation d'une extension QGIS peut être (trop) méconnue : Layers Menu From Project + +[Commenter cet article :fontawesome-solid-comments:](#__comments "Aller aux commentaires"){: .md-button } +{: align=middle } + +---- + +## Menus magiques - par Émilie + +J'ai découvert il y a déjà plusieurs années, l'outil "layers menu from project" et depuis, les utilisateurs ne jurent plus que par ça. Chez nous, on l'appelle "menu magique". + +### Pourquoi c'est magique + +Layers menu from project répond aux questions récurrentes des utilisateurs : où est stockée la donnée (sur le serveur, dans une base de données, dans un flux WMS ?), qu'elle est la dernière version, comment dois-je la représenter ? Les données sont désormais accessibles en 2 clicks, depuis des menus intégrés directement à QGIS. + +Grâce à LMFP, en deux coups de baguette magique, la donnée est affichée ! + +![Be Qool](https://cdn.geotribu.fr/img/articles-blog-rdp/articles/2024/retex_layers_menu_from_project/be-qool_myriade.png){: .img-center loading=lazy } + +### Comment ça fonctionne ? + +Les entrées du menu correspondent aux couches stockées dans un projet QGIS (qgs ou qgz), accessible depuis les postes utilisateurs. Les données peuvent être vecteurs ou rasters, des fichiers plats, issues d'une base de données ou des flux, et toute la configuration de la couche est conservée : symbologie, actions, mise en forme de la table attributaire, formulaire, notes de couche,… + +Concrètement, l’administrateur prépare le.s projet.s QGIS, l’utilisateur le pointe dans le plugin LMFP et le tour est joué. + +![QGIS - Exemple de menus générés par le plugin Layers Menu From Project](https://cdn.geotribu.fr/img/articles-blog-rdp/articles/2024/retex_layers_menu_from_project/LMFP_QGIS_EP-Loire_exemple.webp){: .img-center loading=lazy } + + +!!! tip "Astuce déploiement" + ![logo QDT (QGIS Deployment Toolbelt)](https://cdn.geotribu.fr/img/logos-icones/logiciels_librairies/qdt.webp){: .img-thumbnail-left } + + Pour encore plus de rapidité côté administrateur et de simplicité côté utilisateur, le déploiement peut se faire via [QGIS Deployment Toolbelt (QDT)](https://qgis-deployment.github.io/qgis-deployment-toolbelt-cli/#) : installation du plugin et paramétrage automatique selon les profils utilisateurs. + + +### L'association avec une base de données PostgreSQL + +Avec une base PG, je peux afficher les couches directement depuis une requête, plus besoin de stocker des vues qui induisent des dépendances parfois complexes. En revanche, attention, le mode de connexion à la base (identifiant/mot de passe) est également stocké. + +!!! tip "Astuce sécurité" + Pour contourner cette difficulté, j'ajoute des couches depuis une connexion dont je n'ai pas sauvegardé les paramètres d'authentification. Ainsi, l'utilisateur est invité à saisir ses propres identifiants. + +### Une limite de taille ? + +Dans la théorie, non. En revanche, un projet source avec trop de couches va mettre beaucoup de temps à s'ouvrir et c'est l'administrateur qui va être embêté pour faire ses mises à jour. Mais l'outil propose une solution : il est possible de créer une entrée (un menu) à partir de plusieurs projets QGIS. Ainsi, on peut avoir plusieurs petits projets plus faciles à maintenir plutôt qu'un seul gros projet. + +Pour l'utilisateur, un menu trop long peut être inconfortable. Pour remédier aux listes trop longues, plus ou moins bien organisées, il est possible de grouper les couches en sous-menu (voire sous-sous-menu) en utilisant les groupes de couches. Un groupe de couches vide peut également être utilisé comme séparateur. + +### En action + +Les actions des couches sont également conservées. On peut par exemple permettre, au clic sur des entités, d'ouvrir une page web, de charger des dalles raster ou des photos (moyennant quelques lignes de Python) + +!!! quote "La conclusion d'Émilie" + En interne, on adore la magie. + +---- + +## LE catalogue - par Céline + +De mon côté, c'est sur un outil mutualisé par plusieurs structures que LMFP a changé la donne ! + +**C'est pratique, voilà pourquoi !** + +### Du côté utilisateur + +Une base de données pour plusieurs structures, ça veut dire plusieurs utilisateurs plus ou moins habitués à l'utilisation de QGIS. +**La formation et l'accompagnement ne font pas tout, il nous fallait une solution "User friendly"** ergonomique et facile à lire pour n'importe qui. +Du coup, la liste des couches configurées depuis la base de données dans l'explorateur : ça ne fonctionne pas ! Un menu dédié, qu'on a appelé "catalogue" : c'est explicite et c'est facile pour tout le monde. + +![Le plugin LMFP rend les utilisateurs finaux heureux - Testé en laboratoire](https://cdn.geotribu.fr/img/articles-blog-rdp/articles/2024/retex_layers_menu_from_project/lmfp_utilisateur_qgis_malheureux_heureux.webp){: .img-center loading=lazy } + +### Du côté administrateur + +La liste des couches configurée depuis la base de données dans l'explorateur : ça ne fonctionne pas non plus ! Il faudrait nommer les schémas, tables et vues et que tout soit rangé en pensant à l'utilisateur ... ou utiliser un schéma dédié avec toutes les vues renommées ... +Avec LMFP : pas de sujet ! **Peu importe le modèle de données, c'est le nommage et la configuration dans le projet QGIS utilisé qui comptent** (et bienvenue aux accents et aux espaces). + +!!! tip "Autre avantage" + Étant donné qu'il est possible aussi de mettre des flux, on s'épargne des actions de mise à jour et on remercie les producteurs de gérer leurs mises à jour tous seuls ! + +Comme dit précédemment : la principale contrainte est alors liée au maintien du projet QGIS en entrée du plugin et à l'accès des utilisateurs à ce projet. Chez nous, il est enregistré en base de données. Une authentification avec un identifiant / mot de passe est enregistrée à la première connexion de l'utilisateur, qui lui donne accès au projet via le menu et aux différentes données en base (en lecture ou en écriture). + +!!! tip "Encore plus de paillettes" + En plus des groupes, sous-groupes et agencement de différents projets, il est possible de créer des sections avec des titres et des séparateurs. Rendez-vous sur la documentation du plugin pour rendre tout ça encore plus beau ! [C'est par ici](https://aeag.github.io/MenuFromProject-Qgis-Plugin/usage/fr_use.html#). + +Pour finir, la **cerise sur le gateau : la mise à jour d'un outil sans réinstallation ou téléchargement.** +Notre outil est en constante évolution : champs, listes de valeurs, symbologie ... on change des trucs régulièrement (on corrige aussi des fautes de frappe dans les formulaires par exemple...). Il suffit simplement à l'utilisateur de recharger la couche depuis le menu pour que tout soit à jour : pas besoin de redémmarrer QGIS, réinstaller une extension, aller chercher un style enregistré quelque part ou encore télécharger et écraser un projet QGIS ! + +### L'évolution du plugin + +Il n'y a pas que nos outils qui évoluent, le plugin aussi ! +L'année dernière, on a commencé à intégrer des relations dans notre projet QGIS. Le problème : charger une couche depuis le menu ne chargeait ni l'autre (ou les autres) couche(s) ni la relation. + +Un ticket Git, quelques échanges avec le développeur : et voilà, problème réglé. + +Aujourd'hui, on a remarqué d'autres limites à cette extension (nul n'est parfait ...) alors on va continuer d'apporter notre contribution et nos retours pour la faire évoluer. Et quand on est plusieurs concernés, autant mutualiser, et c'est ce qu'on va faire avec d'autres structures qui utilisent ce plugin ! + +!!! quote "La conclusion de Céline" + User et Administrateur friendly ! + +---- + +## En résumé + + +### Nos :material-plus-thick: + + +* Facile d'utilisation pour les utilisateurs et adaptable par groupes d'utilisateurs +* Facile à configurer +* Permets de rendre accessible des données issues de différentes sources (base de données, fichiers, flux, requêtes...) +* Permets de gérer facilement les styles (symbologie, formulaires, actions) +* Mises à jour des données et styles facilitées +* Une communauté de fans grandissante qui va permettre de faire évoluer l'extension pour encore plus de magie ! + + +### Nos :material-minus-thick: + + +* Attention aux menus trop longs : le projet initial est lourd, le chargement trop impactant sur les perfs d'ouverture du logiciel +* Trop de menus différents : temps d'ouverture de QGIS plus long + +* Des optimisations à faire côté performances dans certains cas techniques + +!!! success "Le mot de la fin" + Un grand merci à tous les développeurs et financeurs des évolutions du plugin LMFP ! + +---- + + + +{% include "licenses/default.md" %} diff --git a/content/team/celine-pornin.md b/content/team/celine-pornin.md new file mode 100644 index 0000000000..2fba87795f --- /dev/null +++ b/content/team/celine-pornin.md @@ -0,0 +1,21 @@ +--- +title: Céline Pornin +categories: + - contributeur +social: + - bluesky: + - github: cpornin + - gitlab: + - linkedin: + - mail: + - mastodon: + - instance: mapstodon.space + - username: CelinePnn + - twitter: +--- + +# Céline Pornin + + +Responsable d'un service SIG dans une structure d'ingénierie publique dédiée à l'Eau, Charente Eaux, je mène des projets de solutions SIG mutualisées et libres pour les collectivités du territoire charentais. + diff --git a/content/team/emilie-bigorne.md b/content/team/emilie-bigorne.md new file mode 100644 index 0000000000..1da69a13a0 --- /dev/null +++ b/content/team/emilie-bigorne.md @@ -0,0 +1,24 @@ +--- +title: Émilie BIGORNE +categories: + - contributeur +social: + - bluesky: + - github: EmilieEPLoire + - gitlab: + - linkedin: + - mail: + - mastodon: + - instance: + - username: + - openstreetmap: + - osgeo: + - twitter: + - website: +--- + +# Emilie BIGORNE + + +Géomaticienne à l'Établissement public Loire depuis 20 ans, j'accompagne les chargés de mission dans leur quotidien : accessibilité des données, automatisation des tâches, conseils. +