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

IGN API Géoportail Discussion :

Comment écrire quelque chose à des coordonnées précises ?


Sujet :

IGN API Géoportail

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de Zebulon777
    Homme Profil pro
    Informaticien
    Inscrit en
    Février 2005
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Février 2005
    Messages : 1 327
    Par défaut Comment écrire quelque chose à des coordonnées précises ?
    Bonjour tout le monde,
    Je m'explique, après une recherche sur la carte, j'affiche une punaise et je voudrai que le nom de la ville soit affiché à côté ou au-dessus de cette punaise.

    Voici mon code actuel :

    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
            // On crée le point
            var punaise = new OpenLayers.Feature.Vector(
              geocoded_commune_center, 
              {name:resultat.features[0].attributes.address.places[0].name}, // on récupère le nom de la ville géocodé (au cas où il faudrait s'en resservir)
              { // Style du point
    //            externalGraphic:'http://blog.zelieux.com/wp-content/uploads/2010/10/punaise.png', 
                externalGraphic:'./Images/Recherche2_32x32.png', 
                pointRadius:25
              }
            );
    
    		WVilleRecherchee = resultat.features[0].attributes.address.places[0].name;
    		
            // on ajoute le point à la couche
            commune_layer.addFeatures([punaise]);
            WZoomRecherche = 12;
            // On recentre la carte sur le résultat
            map.setLonLatCenter(geocoded_commune_center.x, geocoded_commune_center.y, WZoomRecherche, false, false);
    Merci d'avance pour votre aide.

  2. #2
    Membre chevronné Avatar de acarme
    Femme Profil pro
    Ingénieur d'études en Géomatique
    Inscrit en
    Avril 2013
    Messages
    237
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études en Géomatique
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2013
    Messages : 237
    Par défaut
    Il est possible de le faire comme sur cet exemple : http://api.ign.fr/tech-docs-js/examp...simple6.1.html

    en créant un StyleMap de ce type :
    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
    styleMap:new OpenLayers.StyleMap({
                                        "default": new OpenLayers.Style(
                                            OpenLayers.Util.applyDefaults({
                                                fillColor: "#FFFF00",
                                                fillOpacity: 0.75,
                                                strokeColor: "#FF9900",
                                                strokeWidth: 2,
                                                graphicZIndex: "${zIndex}",
                                                graphicName: "triangle",
                                                pointRadius: 8,
                                                //see context object below
                                                label:"${getName}",
                                                labelAlign: "rb",
                                                labelXOffset: -20,
                                                labelYOffset: -20,
                                                labelBackgroundColor: "#FFFF00",
                                                labelBorderColor: "black",
                                                labelBorderSize: "1px",
                                                fontColor: "black",
                                                fontWeight: "bold",
                                                fontSize: "12px",
                                                fontFamily: "Courier New, monospace"
                                            },OpenLayers.Feature.Vector.style["default"]),{
                                                context:{
                                                    getName: function(f) {
                                                        if (f.attributes['typeName']=='wpt') {
                                                            return f.attributes['name'];
                                                        }
                                                        return '';
                                                    }
                                                }
                                            }),
                                        "select": new OpenLayers.Style(
                                            OpenLayers.Util.applyDefaults({
                                                fillColor: "#FF9900",
                                                fillOpacity: 0.75,
                                                strokeColor: "#FFFF00",
                                                strokeWidth: 4,
                                                pointRadius: 12
                                            },OpenLayers.Feature.Vector.style["select"]))
                                    }),

  3. #3
    Membre éclairé Avatar de Zébulon-21
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    392
    Détails du profil
    Informations personnelles :
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Mai 2009
    Messages : 392
    Par défaut
    Et voici un autre exemple

  4. #4
    Membre éprouvé Avatar de Zebulon777
    Homme Profil pro
    Informaticien
    Inscrit en
    Février 2005
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Février 2005
    Messages : 1 327
    Par défaut
    Désolé, mais je ne comprends pas : où est-ce qu'on met les coordonnées ?

  5. #5
    Membre chevronné Avatar de acarme
    Femme Profil pro
    Ingénieur d'études en Géomatique
    Inscrit en
    Avril 2013
    Messages
    237
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études en Géomatique
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2013
    Messages : 237
    Par défaut
    En fait l'idée était d'afficher un label (le nom de ta commune) dans le style d'un point (de ta punaise)..

    Je n'ai peut être pas bien compris ton besoin..

  6. #6
    Membre Expert Avatar de gcebelieu
    Homme Profil pro
    Ingénieur Géographe et Cartographe
    Inscrit en
    Novembre 2010
    Messages
    1 106
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Géographe et Cartographe
    Secteur : Service public

    Informations forums :
    Inscription : Novembre 2010
    Messages : 1 106
    Par défaut
    Citation Envoyé par Zebulon777 Voir le message
    Désolé, mais je ne comprends pas : où est-ce qu'on met les coordonnées ?
    Avec les réserves levées par acarme (si ton besoin est bien compris) :

    les coordonnées d'ancrage de ton texte sont celle du point auquel il est attaché. A savoir, dans ton exemple : geocoded_commune_center.

    Ensuite, tu peux déplacer ton texte par rapport à ce point en jouant sur les propriétés de style : labelXOffset et labelYOffset que tu vas rajouter au style de ton point.

  7. #7
    Membre éprouvé Avatar de Zebulon777
    Homme Profil pro
    Informaticien
    Inscrit en
    Février 2005
    Messages
    1 327
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Février 2005
    Messages : 1 327
    Par défaut
    Purée, c'est super compliqué pour un truc tout simple !
    Lorsque je créé le point avec ma punaise, il n'y a pas un moyen simple pour lui adjoindre le texte de la recherche ?
    Un truc du genre :

    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
            // On crée le point
            var punaise = new OpenLayers.Feature.Vector(
              geocoded_commune_center, 
              {name:resultat.features[0].attributes.address.places[0].name}, // on récupère le nom de la ville géocodé (au cas où il faudrait s'en resservir)
              { // Style du point
    //            externalGraphic:'http://blog.zelieux.com/wp-content/uploads/2010/10/punaise.png', 
                externalGraphic:'./Images/Recherche2_32x32.png', 
                pointRadius:25
              }
            );
    
    		WVilleRecherchee = resultat.features[0].attributes.address.places[0].name;
    		
            // on ajoute le point à la couche
            commune_layer.addFeatures([punaise]) + WVilleRecherchee ;
            WZoomRecherche = 10;
            // On recentre la carte sur le résultat
            map.setLonLatCenter(geocoded_commune_center.x, geocoded_commune_center.y, WZoomRecherche, false, false);

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

Discussions similaires

  1. Lors d'un choix écrire quelque chose
    Par Devilju69 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 19/12/2013, 18h37
  2. [C#] Centrer une image sur des coordonnées précises
    Par Towandaa dans le forum Windows Presentation Foundation
    Réponses: 1
    Dernier message: 27/03/2012, 16h00
  3. JSP, Taglib, comment faire quelque chose de propre
    Par Arget dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 22/12/2011, 19h41
  4. Réponses: 5
    Dernier message: 14/12/2009, 09h36
  5. Réponses: 13
    Dernier message: 07/08/2006, 10h13

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