forked from yukuku/telebot
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathgeoUtils.py
60 lines (50 loc) · 1.96 KB
/
geoUtils.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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
from geopy.geocoders import Nominatim
from geopy.geocoders import GoogleV3
from geopy.distance import vincenty
from geopy.exc import GeocoderServiceError
import key
import logging
from geoLocation import GeoLocation
#https://raw.githubusercontent.com/dakk/Italia.json/master/italia_comuni.json
GEOLOCATOR_1 = Nominatim()
GEOLOCATOR_2 = GoogleV3(key.GOOGLE_API_KEY)
def getLocationFromAddress(locationName):
try:
for g in [GEOLOCATOR_1, GEOLOCATOR_2]:
location = g.geocode(
#locationName, timeout=10, exactly_one=True, language='it', region='it') #default one answer for Nominatim (not google)
locationName, timeout=10, exactly_one=True, language='it') # default one answer for Nominatim (not google)
if location :
return location
except GeocoderServiceError:
logging.error('GeocoderServiceError occurred')
def distance(point1, point2):
#point1 = (41.49008, -71.312796)
#point2 = (41.499498, -81.695391)
return vincenty(point1, point2).kilometers
def getBoxCoordinates(lat, lon, radius):
loc = GeoLocation.from_degrees(lat, lon)
boxMinMaxCorners = loc.bounding_locations(radius)
boxMinCorners = boxMinMaxCorners[0]
boxMaxCorners = boxMinMaxCorners[1]
latMin = boxMinCorners.deg_lat
lonMin = boxMinCorners.deg_lon
latMax = boxMaxCorners.deg_lat
lonMax = boxMaxCorners.deg_lon
return latMin, lonMin, latMax, lonMax
# lat, lon, poly is a list of lat lon coords
def point_inside_polygon(x,y,poly):
n = len(poly)
inside =False
p1x,p1y = poly[0]
for i in range(n+1):
p2x,p2y = poly[i % n]
if y > min(p1y,p2y):
if y <= max(p1y,p2y):
if x <= max(p1x,p2x):
if p1y != p2y:
xinters = (y-p1y)*(p2x-p1x)/(p2y-p1y)+p1x
if p1x == p2x or x <= xinters:
inside = not inside
p1x,p1y = p2x,p2y
return inside