経度と緯度の2ポイントの距離|範囲!



Longitude Latitude Two Points Distance Range



!最初にこれを入手してください。私はインターネット上でたくさんのアルゴリズムを見つけましたが、実用的なものはほとんどなく、それらのいくつかは抽象的で、整理され、共有されています!

public class LatLonUtil {

Private static final double PI = 3.14159265 //Old truth
Private static final double EARTH_RADIUS = 6378137 //Equatorial radius
private static final double RAD = Math.PI / 180.0

//@see http://snipperize.todayclose.com/snippet/php/SQL-Query-to-Find-All-Retailers-Within-a-Given-Radius-of-a-Latitude-and-Longitude--65095/
//The circumference of the earth is 24,901 miles.
//24,901/360 = 69.17 miles / degree
/**
* @param raidus unit meters
* return minLat,minLng,maxLat,maxLng
*/
public static double[] getAround(double lat,double lon,int raidus){

Double latitude = lat
Double longitude = lon

Double degree = (24901*1609)/360.0
double raidusMile = raidus

Double dpmLat = 1/degree
Double radiusLat = dpmLat*raidusMile
Double minLat = latitude - radiusLat
Double maxLat = latitude + radiusLat

Double mpdLng = degree*Math.cos(latitude * (PI/180))
Double dpmLng = 1 / mpdLng
Double radiusLng = dpmLng*raidusMile
Double minLng = longitude - radiusLng
Double maxLng = longitude + radiusLng
//System.out.println('['+minLat+','+minLng+','+maxLat+','+maxLng+']')
return new double[]{minLat,minLng,maxLat,maxLng}
}

/**
* Calculate the distance between two points in units of meters based on the latitude and longitude coordinates (double value) between two points
* @param lng1
* @param lat1
* @param lng2
* @param lat2
* @return
*/
public static double getDistance(double lng1, double lat1, double lng2, double lat2)
{
double radLat1 = lat1*RAD
double radLat2 = lat2*RAD
double a = radLat1 - radLat2
double b = (lng1 - lng2)*RAD
double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) +
Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)))
s = s * EARTH_RADIUS
s = Math.round(s * 10000) / 10000
return s
}

public static void main(String[] args){
Double lat1 = 34.264648
Double lon1 = 108.952736

int radius = 1000
//[34.25566276027792,108.94186385411045,34.27363323972208,108.96360814588955]
getAround(lat1,lon1,radius)

//911717.0 34.264648,108.952736,39.904549,116.407288
double dis = getDistance(108.952736,34.264648,116.407288,39.904549)
System.out.println(dis)
}
}

上記、最大経度、緯度、最小経度、緯度! 2点間の距離
上記は他のものを引用し、非常によく書かれていますが、いくつかの問題があります!過去の結果は十分に直接的ではありません。

//object-c, get the latitude and longitude of the search target
var geocoder = new GClientGeocoder()
geocoder.getLocations(address, function($){
var lalton = $.Placemark[0].Point.coordinates
areaMap(lalton[1],lalton[0])
//alert(lalton[1] + ',' + lalton[0])
})

[color = red]ここのデータベースはmysql [/ color]であることに注意してください

SELECT id, ( 3959 * acos( cos( radians(lat_t) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(lng_t) )
+ sin( radians(lat_t) ) * sin( radians( lat ) ) ) ) AS distance
FROM Stores HAVING distance <25
ORDER BY distance
LIMIT 0,20


SELECT * from
app_activity where
(3959*acos(cos(radians(36.0971114))*cos(radians(latitude))*cos(radians(longitude)-radians(103.6130684))+sin(radians(36.0971114))*sin(radians(latitude)))) <1

[color = red] 1、3959は地球の半径です
2、25は検索半径です
3、3959、および25は、「km」に変更する必要がある場合は「マイル」で計算され、1.609931 [/ color]を掛ける必要があります。


select * from location where sqrt(
(
((113.914619-longitude)*PI()*12656*cos(((22.50128+latitude)/2)*PI()/180)/180)
*
((113.914619-longitude)*PI()*12656*cos (((22.50128+latitude)/2)*PI()/180)/180)
)
+
(
((22.50128-latitude)*PI()*12656/180)
*
((22.50128-latitude)*PI()*12656/180)
)

経度:113.914619
緯度:22.50128
範囲:2km
経度はデータテーブルの経度フィールドです
緯度はデータテーブルの緯度フィールドです


Earth online http://www.earthol.com/で、緯度と経度のテストを取得します