2013-03-27 21 views
7

Ho una mappa disegnata con leaflet.js. Se fornisco il valore di longitudine e latitudine come input Posso identificare il poligono? Posso ottenere uno script lato client per questo?identificare quale è il poligono da latitudine e longitudine

+0

è necessario dare valore LAT e lng per poligono shape.if si dà uno lng lat valore che rappresenterà il punto. Mentre si dà il maggior numero di linee, si disegnerà il poligono. L'inizio e la fine del latng dovrebbe essere lo stesso. – tamilmani

+0

Sì, cercare un algoritmo geodetico point-in-poligono (PIP). – pp19dd

+1

Ho una mappa disegnata utilizzando alcuni set di valori lat e lng. Ma ora voglio conoscere l'id del poligono da un insieme di valori lat e lng. – Sudha

risposta

5

ottenuto una risposta come segue:

// Questo è basato sul 'punto nel poligono algoritmo'

function getPoint() { 
    float x=-89.82421875;  //x and y represents the lat and lng values 
    float y= 40.18307014852533; 
    var a = boundaries; //the coordinates used to draw the map 
    for (i = 0; i < a.features.length; i++) { 
     PointInPolygon(x,y, a.features[i].geometry.coordinates[0], i); 
    } 
}; 

function PointInPolygon(pointX, pointY, _vertices, number) { 
     var j = _vertices.length - 1; 
     var oddNodes = false; 
     var polyX, polyY,polyXJ,polyYJ; 

     for (var i = 0; i < _vertices.length; i++) { 
      polyY = parseFloat(_vertices[i].toString().split(",")[1]); 
      polyX = parseFloat(_vertices[i].toString().split(",")[0]); 
      polyXJ = parseFloat(_vertices[j].toString().split(",")[0]); 
      polyYJ = parseFloat(_vertices[j].toString().split(",")[1]); 
      if (polyY < pointY && polyYJ >= pointY || 
       polyYJ < pointY && polyY >= pointY) { 
       if (polyX + 
        (pointY - polyY)/(polyYJ - polyY) * (polyXJ - polyX) < pointX) 
       { 
        oddNodes = !oddNodes; 
       } 
      } 
      j = i; 
     } 
     if (oddNodes == true) { 
      map._layers[number+1].fire('click');    //fire the map click event 
     } 
    } 
Problemi correlati