forked from yinger650/BaiduMap_tiles
-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathgmap_utils.py
executable file
·45 lines (39 loc) · 1.23 KB
/
gmap_utils.py
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
# http://oregonarc.com/2011/02/command-line-tile-cutter-for-google-maps-improved/
# http://media.oregonarc.com/fish/tile.py
import math
import urllib.request, urllib.parse, urllib.error
import urllib.request, urllib.error, urllib.parse
import json
akey = 'uzIatbtHgfCTr71dWxnHolfZqG6vARNc'
def latlon2px(z,lat,lon):
x = 2**z*(lon+180)/360*256
y = -(.5*math.log((1+math.sin(math.radians(lat)))/(1-math.sin(math.radians(lat))))/math.pi-1)*256*2**(z-1)
return x,y
def latlon2xy(z,lat,lon):
x,y = latlon2px(z,lat,lon)
x = int(x/256)#,int(x%256)
y = int(y/256)#,int(y%256)
return x,y
def bd_latlng2xy(z,lat,lng):
url='http://api.map.baidu.com/geoconv/v1/?'
args = {'coords':str(lng)+','+str(lat),
'from':5,
'to':6,
'output':'json',
'ak':akey}
data = urllib.parse.urlencode(args)
response = urllib.request.urlopen(url+data)
result = response.read()
result = json.loads(result)
loc = result["result"][0]
res = 2**(18-z)
x = loc['x']/res
y = loc['y']/res
return x,y
if __name__ == "__main__":
z=19
lat=31.025819
lng=121.434229
x,y = bd_latlng2xy(z,lat,lng)
print(x//256)
print(y//256) # only right when lat>0 lng>0