Calcule a distância em metros quando você conhece longitude e latitude em java [duplicado

StackOverflow https://stackoverflow.com/questions/837872

Pergunta

Possível duplicata:
Trabalhando com valores de latitude/longitude em java

Duplicado:

Preciso calcular a distância entre dois pontos dados por duas coordenadas. O projeto em que estou trabalhando é um projeto Java, então o código Java será ótimo, mas o pseudo-código também pode ser dado, então eu posso implementá-lo :)

Como você provavelmente sabe, existem três maneiras de representar coordenadas:

  • Graus: minutos: segundos (49 ° 30'00 "n, 123 ° 30'00" W)
  • Graus: minutos decimais (49 ° 30,0 ', -123 ° 30,0'), (49d30,0m, -123d30.0 ')
  • Graus decimais (49,5000 °, -123,5000 °), geralmente com 4-6 números decimais.

É a terceira maneira que minhas coordenadas são entregues, então o código para esses valores será preferido :)

Foi útil?

Solução

Baseado em Outra pergunta no Stackoverflow, Eu recebi este código .. Isso calcula o resultado em medidores, não em milhas :)

 public static float distFrom(float lat1, float lng1, float lat2, float lng2) {
    double earthRadius = 6371000; //meters
    double dLat = Math.toRadians(lat2-lat1);
    double dLng = Math.toRadians(lng2-lng1);
    double a = Math.sin(dLat/2) * Math.sin(dLat/2) +
               Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
               Math.sin(dLng/2) * Math.sin(dLng/2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
    float dist = (float) (earthRadius * c);

    return dist;
    }

Outras dicas

Você pode usar o Biblioteca Java Geodesy para GPS, ele usa o Fórmulas de Vincenty que leva em conta a curvatura da superfície da Terra.

A implementação é assim:

import org.gavaghan.geodesy.*;

...

GeodeticCalculator geoCalc = new GeodeticCalculator();

Ellipsoid reference = Ellipsoid.WGS84;  

GlobalPosition pointA = new GlobalPosition(latitude, longitude, 0.0); // Point A

GlobalPosition userPos = new GlobalPosition(userLat, userLon, 0.0); // Point B

double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance(); // Distance between Point A and Point B

A distância resultante está em metros.

Em C ++ é feito assim:

#define LOCAL_PI 3.1415926535897932385 

double ToRadians(double degrees) 
{
  double radians = degrees * LOCAL_PI / 180;
  return radians;
}

double DirectDistance(double lat1, double lng1, double lat2, double lng2) 
{
  double earthRadius = 3958.75;
  double dLat = ToRadians(lat2-lat1);
  double dLng = ToRadians(lng2-lng1);
  double a = sin(dLat/2) * sin(dLat/2) + 
             cos(ToRadians(lat1)) * cos(ToRadians(lat2)) * 
             sin(dLng/2) * sin(dLng/2);
  double c = 2 * atan2(sqrt(a), sqrt(1-a));
  double dist = earthRadius * c;
  double meterConversion = 1609.00;
  return dist * meterConversion;
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top