Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment enregistrer une forme de superposition Google maps dans la base de données ?

Lorsque vous souhaitez simplement stocker les formes d'une manière ou d'une autre, vous pouvez utiliser une chaîne JSON, la stocker par exemple. un Text -column(char serait trop petit pour stocker des polygones/polylignes détaillés )

Remarque :lorsque vous créez la chaîne JSON, vous devez convertir les propriétés (par exemple en tableaux ou objets natifs), vous ne pouvez pas stocker directement par exemple LatLng, car le prototype sera perdu lors de sa sauvegarde. Les chemins des polylignes/polygones peuvent être stockés codés

Une autre approche :utilisez plusieurs colonnes, par ex.

  1. une colonne(varchar ) où vous stockez le type (LatLng, Circle, Polyline, etc.)
  2. une colonne(geometry ) où vous stockez les caractéristiques géométriques (LatLng, Polygon ou Polyline)
  3. une colonne(int ) où vous stockez un rayon (utilisé lorsque vous insérez un cercle)
  4. éventuellement colonne(text ) où vous stockez les options de style (si nécessaire)

La première suggestion serait suffisante lorsque vous souhaitez simplement le stocker.

Lorsque vous devez pouvoir sélectionner des formes particulières, par exemple pour une zone donnée, utilisez la 2ème suggestion.Voir http://dev.mysql.com/doc/refman/5.0/en/spatial-extensions.html pour le détail des extensions spatiales

2 fonctions qui soit suppriment les références circulaires et créent des objets stockables, soit restaurent les superpositions à partir de ces objets stockés.

var IO={
  //returns array with storable google.maps.Overlay-definitions
  IN:function(arr,//array with google.maps.Overlays
              encoded//boolean indicating if pathes should be stored encoded
              ){
      var shapes     = [],
          goo=google.maps,
          shape,tmp;

      for(var i = 0; i < arr.length; i++)
      {   
        shape=arr[i];
        tmp={type:this.t_(shape.type),id:shape.id||null};


        switch(tmp.type){
           case 'CIRCLE':
              tmp.radius=shape.getRadius();
              tmp.geometry=this.p_(shape.getCenter());
            break;
           case 'MARKER': 
              tmp.geometry=this.p_(shape.getPosition());   
            break;  
           case 'RECTANGLE': 
              tmp.geometry=this.b_(shape.getBounds()); 
             break;   
           case 'POLYLINE': 
              tmp.geometry=this.l_(shape.getPath(),encoded);
             break;   
           case 'POLYGON': 
              tmp.geometry=this.m_(shape.getPaths(),encoded);

             break;   
       }
       shapes.push(tmp);
    }

    return shapes;
  },
  //returns array with google.maps.Overlays
  OUT:function(arr,//array containg the stored shape-definitions
               map//map where to draw the shapes
               ){
      var shapes     = [],
          goo=google.maps,
          map=map||null,
          shape,tmp;

      for(var i = 0; i < arr.length; i++)
      {   
        shape=arr[i];       

        switch(shape.type){
           case 'CIRCLE':
             tmp=new goo.Circle({radius:Number(shape.radius),
                                  center:this.pp_.apply(this,shape.geometry)});
            break;
           case 'MARKER': 
             tmp=new goo.Marker({position:this.pp_.apply(this,shape.geometry)});
            break;  
           case 'RECTANGLE': 
             tmp=new goo.Rectangle({bounds:this.bb_.apply(this,shape.geometry)});
             break;   
           case 'POLYLINE': 
             tmp=new goo.Polyline({path:this.ll_(shape.geometry)});
             break;   
           case 'POLYGON': 
             tmp=new goo.Polygon({paths:this.mm_(shape.geometry)});

             break;   
       }
       tmp.setValues({map:map,id:shape.id})
       shapes.push(tmp);
    }
    return shapes;
  },
  l_:function(path,e){
    path=(path.getArray)?path.getArray():path;
    if(e){
      return google.maps.geometry.encoding.encodePath(path);
    }else{
      var r=[];
      for(var i=0;i<path.length;++i){
        r.push(this.p_(path[i]));
      }
      return r;
    }
  },
  ll_:function(path){
    if(typeof path==='string'){
      return google.maps.geometry.encoding.decodePath(path);
    }
    else{
      var r=[];
      for(var i=0;i<path.length;++i){
        r.push(this.pp_.apply(this,path[i]));
      }
      return r;
    }
  },

  m_:function(paths,e){
    var r=[];
    paths=(paths.getArray)?paths.getArray():paths;
    for(var i=0;i<paths.length;++i){
        r.push(this.l_(paths[i],e));
      }
     return r;
  },
  mm_:function(paths){
    var r=[];
    for(var i=0;i<paths.length;++i){
        r.push(this.ll_.call(this,paths[i]));

      }
     return r;
  },
  p_:function(latLng){
    return([latLng.lat(),latLng.lng()]);
  },
  pp_:function(lat,lng){
    return new google.maps.LatLng(lat,lng);
  },
  b_:function(bounds){
    return([this.p_(bounds.getSouthWest()),
            this.p_(bounds.getNorthEast())]);
  },
  bb_:function(sw,ne){
    return new google.maps.LatLngBounds(this.pp_.apply(this,sw),
                                        this.pp_.apply(this,ne));
  },
  t_:function(s){
    var t=['CIRCLE','MARKER','RECTANGLE','POLYLINE','POLYGON'];
    for(var i=0;i<t.length;++i){
       if(s===google.maps.drawing.OverlayType[t[i]]){
         return t[i];
       }
    }
  }

}

Le tableau retourné par IO.IN peut être envoyé à un script côté serveur. Le script côté serveur doit itérer sur ce tableau et INSÉRER une chaîne JSON dans la table :

<?php
$mysqli = new mysqli(/*args*/);
$stmt = $mysqli->prepare('INSERT INTO `tableName`(`columnName`) VALUES (?)');
$stmt->bind_param('s', $json);

foreach($_POST['shapes'] as $value){
  $json = json_encode($value);
  $stmt->execute();
}
?>

pour restaurer les formes, récupérez-les :

<?php
$json=array();
$res=$mysqli->query('SELECT `columnName` from `tableName`');
while ($row = $res->fetch_assoc()) {
        $json[]=json_decode($row['columnName']);
    }
$res->close();
$json=json_encode($json);
?>

et passez le résultat à IO.OUT() :

IO.OUT(<?php echo $json;?>, someGoogleMapsInstance);

Démo :http://jsfiddle.net/doktormolle/EdZk4/show/