IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques & Frameworks Discussion :

Insérer Leaflet marker clusterGroup sans GeoJson [LeafLet]


Sujet :

Bibliothèques & Frameworks

  1. #1
    Candidat au Club
    Femme Profil pro
    Chargé d'affaire
    Inscrit en
    Mai 2024
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2024
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Insérer Leaflet marker clusterGroup sans GeoJson
    Bonjour,

    Je précise que je suis plutôt débutante.
    Dans le cadre de la création d'une carte interactive avec Leaflet, je souhaite créer des marker cluster Groups, mais la plupart des tutos ou exemples que je trouve passent par GeoJson, cependant, moi, j'ai juste mes points GPS avec description sans être passée par GeoJson, et je compte juste ajouter ce qu'il faut pour en faire des clusters car j'en ai beaucoup géographiquement proches.

    J'ai ajouté la bibliothèque nécessaire, mais c'est après, dans le code, où je ne vois pas trop ce qu'il faut ajuster.

    En gros ma liste de points GPS se présente comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    var markersData : {
              "Catégorie 1": [
              {lat: xxxxx, lng: xxxxxx, name: "xxxxxxxxx", description: "xxxxxxxxxxxxxxxxxx", image: ["xxxxx"]},
              {lat: xxxxx, lng: xxxxxx, name: "xxxxxxxxx", description: "xxxxxxxxxxxxxxxxxx", image: ["xxxxx"]},
               etc
               ]
    Ensuite, mon code est le suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    // Créer des couches pour chaque catégorie de marqueurs
        var layers = {};
        for (var category in markersData) {
          layers[category] = L.layerGroup();
        }
        // Ajouter des marqueurs à partir de données pour chaque catégorie
        for (var category in markersData) {
          markersData[category].forEach(function(data) {
            var marker = L.marker([data.lat, data.lng], {icon: customIcon});
            var popupContent = `
              <div class="popup-title">${data.name}</div>
              <div class="popup-description">
                <strong>Valorisation:</strong> ${data.valorisation}<br>
                <strong>Partenaires:</strong> ${data.partenaires.join(", ")}
              </div>
              `;
            var imageHTML = data.image ? `<img class='popup-image' src='images/${data.image}' alt='Image'>` : ''; // Vérifie si une image est spécifiée dans les données
            popupContent += `<div class='popup-content'>${imageHTML}</div>`; // Ajoute le code HTML de l'image à popupContent
                    marker.bindPopup(popupContent);
            layers[category].addLayer(marker); // Ajouter le marqueur à la couche correspondante
          });
        }
        // Ajouter les couches au contrôle des couches
        L.control.layers(null, layers).addTo(map);
        // Activer toutes les couches par défaut
        for (var category in layers) {
        layers[category].addTo(map);
        }
        // Mettre à jour la légende lorsque les couches sont activées/désactivées
        map.on('overlayadd overlayremove', function(eventLayer) {
          var legend = document.getElementById('legend');
          legend.innerHTML = ''; // Effacer le contenu de la légende
          for (var category in layers) {
            var layer = layers[category];
            if (map.hasLayer(layer)) {
              var item = document.createElement('div');
              item.className = 'legend-item';
              var marker = document.createElement('span');
              marker.style.backgroundColor = layer.options.color;
              item.appendChild(marker);
              item.appendChild(document.createTextNode(category));
              legend.appendChild(item);
            }
          }
        });
        // Initialiser la légende
        var legend = document.getElementById('legend');
        for (var category in layers) {
          var layer = layers[category];
          var item = document.createElement('div');
          item.className = 'legend-item';
          var marker = document.createElement('span');
          marker.style.backgroundColor = layer.options.color;
          item.appendChild(marker);
          item.appendChild(document.createTextNode(category));
          legend.appendChild(item);
        }
        // Gérer le clic sur le lien pour dérouler la pop-up
        marker.on('popupopen', function(e) {
            var popup = e.popup;
            var content = popup.getContent();
            var popupToggle = content.querySelector('.popup-toggle');
            var popupContent = content.querySelector('.popup-content');
            popupToggle.addEventListener('click', function() {
              if (popupContent.style.maxHeight === '200px') {
                popupContent.style.maxHeight = 'none';
                popupToggle.innerHTML = '-';
              } else {
                popupContent.style.maxHeight = '200px';
                popupToggle.innerHTML = '+';
              }
            });
          });

    Est-ce que quelqu'un saurait comment procéder pour créer les clusters ? Que dois-je modifier/ajouter dans mon code ?

    Merci !

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 274
    Points : 15 590
    Points
    15 590
    Par défaut
    d'après ce que j'ai vu, ce n'est pas intégré à leaflet et vous devez ajouter cela :
    https://github.com/Leaflet/Leaflet.markercluster

    la document explique comment mettre des points pour avoir l'effet de regroupement.

  3. #3
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 030
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 030
    Points : 44 375
    Points
    44 375
    Par défaut
    Bonjour,

    @Ariane99i :
    Petit rappel au passage : Les règles du club : IV-G. Remerciements
    Il est de bon ton de remercier la personne qui vous a aidé bénévolement et de lui signaler que sa réponse a bien résolu votre problème ou bien répondu à votre question.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [LeafLet] Lecture des valeurs des markers d'une couche leaflet.
    Par Podzef dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 15/07/2021, 09h47
  2. LEAFLET : marker de l'outil de recherche
    Par saxrub dans le forum IGN API Géoportail
    Réponses: 2
    Dernier message: 05/06/2021, 08h26
  3. [Leaflet] : markers dans PHP
    Par augier26 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 07/11/2018, 20h50
  4. [LeafLet] Transformer markers en polyligne
    Par yole9 dans le forum jQuery
    Réponses: 4
    Dernier message: 15/06/2017, 16h59
  5. Réponses: 1
    Dernier message: 06/03/2013, 22h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo