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 :

Gestion du clic sur un OpenLayers.Layer.Vector


Sujet :

IGN API Géoportail

  1. #1
    Membre régulier

    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    115
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 115
    Points : 120
    Points
    120
    Par défaut Gestion du clic sur un OpenLayers.Layer.Vector
    Bonjour,

    Sur le fond de carte IGN j'ajoute une trace GPX ainsi qu'un marqueur perso sous forme d'un OpenLayers.Layer.Vector, maintenant j'aimerai gérer le clic sur ce marqueur pour disons faire un alert('test'). Dans mon code il s'agit de la variable "pt" ligne 85

    J'ai cru comprendre qu'il fallait passer par une instance de OpenLayers.Control.SelectFeature mais j'ai beau lire la doc Openlayers... je n'arrive à rien...

    Si vous avez des idées pour m'aider , merci d'avance:-)

    Voici mon code :



    Code javascript : 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
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    <script type="text/javascript">
      <!--
        function initGeoportalMap() {
     
        gpxloaded = false ;
     
    	geoportalLoadVISU("GeoportalVisuDiv");
     
    	if (VISU) {
    		VISU.addGeoportalLayers(	['ORTHOIMAGERY.ORTHOPHOTOS:WMSC', 'GEOGRAPHICALGRIDSYSTEMS.MAPS:WMSC'],
                 					 	{
                 					 		'GEOGRAPHICALGRIDSYSTEMS.MAPS:WMSC':{visibility:true},global:{opacity:1},
                 					 		'ORTHOIMAGERY.ORTHOPHOTOS:WMSC':{visibility:false},global:{opacity:1}
                 					 	}
     
                 					);
        }
     
     	VISU.openLayersPanel(false);
    	VISU.openToolsPanel(false);
    	VISU.setInformationPanelVisibility(false) ;
     
       	VISU.getMap().setCenter(VISU.viewerOptions.defaultCenter,VISU.viewerOptions.defaultZoom);
     
        var gpx = VISU.getMap().addLayer("GPX","Itinéraire","http://la-trace.com/itineraires/fileserve/4dd18e6370f2b.gpx", {
     
    	visibility:true, 
    	styleMap:new OpenLayers.StyleMap({
            "default": new OpenLayers.Style(
                OpenLayers.Util.applyDefaults({
                    fillColor: "#DD0000",
                    fillOpacity: 1,
                    strokeColor: "#DD0000",
                    strokeWidth: 4,
                    graphicName: "",
                    pointRadius: 5,
                    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 '';
                        }
                    }
                }),
            "select": new OpenLayers.Style(
                OpenLayers.Util.applyDefaults({
                    fillColor: "#FF9900",
                    fillOpacity: 0.75,
                    strokeColor: "#FFFF00",
                    strokeWidth: 4,
                    pointRadius: 12
                },OpenLayers.Feature.Vector.style["select"]))
        	}),
        	rendererOptions: {
        		zIndexing: true
    		},
    		eventListeners:{
    			"loadend":function(){
     
    				gpxloaded = true ;
    				this.addmarker(gpx) ;
     
    		          if (this.maxExtent) {
    		            this.map.zoomToExtent(this.maxExtent);
    		          }
    		        }
    		},
    		addmarker: function() {
     
    		      //construction du marqueur de depart
    		      position = new OpenLayers.Geometry.Point(3.611429000000, 45.747104000000);
    		      position.transform(OpenLayers.Projection.CRS84, VISU.projection);        
    		      style = {externalGraphic:'http://la-trace.com/assets/pics/marker.png', graphicWidth:24, graphicHeight:48};
    		      pt = new OpenLayers.Feature.Vector(position, null, style);
     
    		      //couche du marqueur
    		      couche = new OpenLayers.Layer.Vector('Marqueurs');
    		      couche.addFeatures([pt]);
     
     
    		      VISU.getMap().addLayer(couche);
    		      var zi= this.getZIndex();
    		      this.setZIndex(couche.getZIndex());
    		      couche.setZIndex(zi);
        	}
     
    	}, {});
     
     
    }
     
    -->
     
     
     
     
    </script>

  2. #2
    Membre régulier

    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    115
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 115
    Points : 120
    Points
    120
    Par défaut
    j'ai changé mon fusil d'épaule et j'ai utilisé un OpenLayers.Layer.Markers avec un OpenLayers.Icon et j'y suis parvenu !

  3. #3
    Expert confirmé
    Homme Profil pro
    Ingénieur cartographe
    Inscrit en
    Avril 2009
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur cartographe
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 173
    Points : 4 224
    Points
    4 224
    Par défaut
    Citation Envoyé par Al3x Voir le message
    j'ai changé mon fusil d'épaule et j'ai utilisé un OpenLayers.Layer.Markers avec un OpenLayers.Icon et j'y suis parvenu !
    Dommage car OpenLayers.Layer.Markers et OpenLayers.Icon n'offrent pas les mêmes fonctionnalités qu'OpenLayers.Layer.Vector et OpenLayers.Feature.Vector

    Voir et

  4. #4
    Membre régulier

    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    115
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 115
    Points : 120
    Points
    120
    Par défaut
    Certes mais ça à le grand mérite de fonctionner :-)

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

Discussions similaires

  1. Réponses: 24
    Dernier message: 23/05/2013, 08h26
  2. gestion du clic sur un bouton en java
    Par einstein007 dans le forum Débuter
    Réponses: 5
    Dernier message: 15/06/2009, 17h08
  3. Réponses: 1
    Dernier message: 15/02/2007, 16h29
  4. [Débutant] gestion d'un clic sur une liste box
    Par claireP23 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 08/01/2007, 15h34
  5. Gestion du clic sur la croix de fermeture !
    Par Atomikx dans le forum MFC
    Réponses: 3
    Dernier message: 15/11/2005, 11h47

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