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

APIs Google Discussion :

Déplacement automatique de marqueur avec traçage [Google Maps]


Sujet :

APIs Google

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Juin 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Chef de projet en SSII

    Informations forums :
    Inscription : Juin 2012
    Messages : 14
    Par défaut Déplacement automatique de marqueur avec traçage
    Bonjour à tous,
    J'ai ce code qui fait le déplacement automatique d'un marqueur avec le traçage.J'ai trouvé ce code:
    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
    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
    <!DOCTYPE html>
    <html lang="fr">
    <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no">
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <title>[Google Maps API V3] Déplacement d'un Marker</title>
    <meta name="Author" content="NoSmoking">
    <style type="text/css">
    html, body {
      height : 100%;
      margin : 0;
      padding : 0;
      font-family : Verdana, Arial;
      font-size : 1em;
    }
    h1 {
      color : #4488bb;
      font-size : 1.3em;
      margin : 0;
      padding : 0.5em;
      border : 1px solid #4488bb;
    }
    #page {
      padding : 0.5em;
    }
    #div_main {
      margin : auto;
      width : 800px;
    }
    #div_carte{
      margin : auto;
      margin-top : 1.0em;
      width : 600px;
      height: 600px;
      border : 1px solid #c0c0c0;
    }
    </style>
    <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
    <script type="text/javascript">
    var tPosition = [
      { 'lat' :45.767299, 'lon' : 4.834329},
      { 'lat' :48.856667, 'lon' : 2.350987},
      { 'lat' :44.837368, 'lon' :-0.576144},
      { 'lat' :43.297612, 'lon' : 5.381042}
    ];
     
    var nbPoint = tPosition.length;
    var iPos = 0;
     
    function movePositionMarker( marker, trajet){
      iPos++;            // incrémentation;
      iPos %= nbPoint;   // pas de débordement
     
      // recup. du point a traiter
      var point = new google.maps.LatLng( tPosition[iPos].lat, tPosition[iPos].lon);
      // deplace le marker
      marker.setPosition( point);
      // ajout point dans polyline
      trajet.getPath().push( point);
      // rappel de la fonction
      setTimeout( function(){
          movePositionMarker( marker, trajet);
        }, 1000);
    }
     
    function initCarte(){
      // init
      var oMap, oMarker;
      var mapOptions = {
        backgroundColor : '#fff',
        mapTypeControl :  false,
        streetViewControl : false,
        zoomControlOptions: {
          style: google.maps.ZoomControlStyle.SMALL
        },
        zoom : 6,
        center : new google.maps.LatLng( 46.80, 1.75),
        mapTypeId: google.maps.MapTypeId.ROADMAP
      };
      // creation de la carte
      oMap = new google.maps.Map(document.getElementById("div_carte"), mapOptions);
      // creation du marqueur
      oMarker = new google.maps.Marker({
        position : new google.maps.LatLng( tPosition[0].lat, tPosition[0].lon),
        map : oMap
      });
    var oPolyline = new google.maps.Polyline({
        'map': oMap
      });
      movePositionMarker( oMarker,oPolyline);
    }
    // init lorsque la page est chargee
    google.maps.event.addDomListener(window, 'load', initCarte);
    </script>
    </head>
    <body>
    <div id="page">
      <div id="div_main">
        <h1>[Google Maps API V3] Déplacement d'un Marker</h1>
        <div id="div_carte"></div>
      </div>
    </div>
    </body>
    </html>
    maintenant je veux que lorsque le marqueur se déplace,il laisse un autre marqueur sur le point précédent pour afficher infobulle.

    Merci d'avance.

  2. #2
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 209
    Par défaut
    Bonjour,
    sur le principe cela est tout simple.
    - avant de mouvoir le marqueur mobile, on récupère la position de celui ci
    - création d'un nouveau marqueur auquel on affecte la position relevée
    - déplacement du marqueur mobile
    ...etc..

    Pour ce faire il te faut modifier la fonction movePositionMarker
    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
    function movePositionMarker( marker, trajet){
      iPos++;            // incrémentation;
      iPos %= nbPoint;   // pas de débordement
     
      // cretaion d'un nouveau marqueur
      var oMarker = new google.maps.Marker({
          'position' : marker.getPosition(),  // position du marker en cours
          'map': marker.getMap()              // map du marker en cours
        });
     
      // recup. du point a traiter
      var point = new google.maps.LatLng( tPosition[iPos].lat, tPosition[iPos].lon);
      // deplace le marker
      marker.setPosition( point);
      // ajout point dans polyline
      trajet.getPath().push( point);
      // rappel de la fonction
      setTimeout( function(){
          movePositionMarker( marker, trajet);
        }, 1000);
    }

  3. #3
    Membre averti
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Juin 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Chef de projet en SSII

    Informations forums :
    Inscription : Juin 2012
    Messages : 14
    Par défaut
    merci beaucoup sa marche

  4. #4
    Membre averti
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Juin 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Chef de projet en SSII

    Informations forums :
    Inscription : Juin 2012
    Messages : 14
    Par défaut
    Bonjour
    Merci beaucoup encore une fois , mais la carte ne se déplace pas avec le marqueur ..
    j'aimerais centrer ma carte google map sur mon marker.
    cet marker provient des coordonnées gps stockées dans une base de données Mysql.

    j'ai utilisé cette fonction mais elle fait le déplacement une seule fois même si on ajoute plusieurs points ..
    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
    function initialize() {
      var mapDiv = document.getElementById('map-canvas');
      var map = new google.maps.Map(mapDiv, {
        center: new google.maps.LatLng(37.4419, -122.1419),
        zoom: 13,
        mapTypeId: google.maps.MapTypeId.ROADMAP
      });
     
      google.maps.event.addListenerOnce(map, 'tilesloaded', function() {
        window.setTimeout(function() {
          map.panTo(new google.maps.LatLng(37.4569, -122.1569));
        }, 1000);
      });
    }

  5. #5
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 209
    Par défaut
    pour centrer la carte sur le nouveau marker il faut le faire dans la fonction de déplacement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      // recup. du point a traiter
      var point = new google.maps.LatLng( tPosition[iPos].lat, tPosition[iPos].lon);
      // deplace le marker
      marker.setPosition( point);
      // centre la carte
      marker.getMap().panTo( point);
    par exemple.

  6. #6
    Membre averti
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Juin 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Chef de projet en SSII

    Informations forums :
    Inscription : Juin 2012
    Messages : 14
    Par défaut
    Merci beaucoup pour votre aide
    ça fonctionne bien..

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

Discussions similaires

  1. [C#]Lier automatiquement un Textbox avec une variable
    Par apoingsfermes dans le forum Windows Forms
    Réponses: 4
    Dernier message: 19/07/2006, 11h21
  2. Démarrer automatiquement une session avec pass
    Par cyberman.inc dans le forum Windows XP
    Réponses: 3
    Dernier message: 07/08/2005, 17h55
  3. [POO] Class Défilementa automatique d'images avec animation
    Par rakoto.n dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 14/01/2005, 18h21
  4. création automatique de table avec createdb??
    Par champion dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 13/09/2004, 09h01
  5. Déplacement "automatique" du curseur
    Par Amenofis dans le forum Composants VCL
    Réponses: 2
    Dernier message: 08/01/2003, 18h57

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