mirror of
https://github.com/marceloprates/prettymaps.git
synced 2025-08-29 09:10:26 +02:00
Added buffer distance in get_streets()
Added a buffer distance in get_streets() to fetch streets that are not fully inside the perimeter.
This commit is contained in:
committed by
GitHub
parent
7f3aa74857
commit
e938eaa614
@@ -80,7 +80,7 @@ def get_geometries(perimeter = None, point = None, radius = None, tags = {}, per
|
||||
return geometries
|
||||
|
||||
# Get streets
|
||||
def get_streets(perimeter = None, point = None, radius = None, layer = 'streets', width = 6, custom_filter = None, circle = True, dilate = 0):
|
||||
def get_streets(perimeter = None, point = None, radius = None, layer = 'streets', width = 6, custom_filter = None, buffer = 0,circle = True, dilate = 0):
|
||||
|
||||
if layer == 'streets':
|
||||
layer = 'highway'
|
||||
@@ -88,13 +88,13 @@ def get_streets(perimeter = None, point = None, radius = None, layer = 'streets'
|
||||
# Boundary defined by polygon (perimeter)
|
||||
if perimeter is not None:
|
||||
# Fetch streets data, project & convert to GDF
|
||||
streets = ox.graph_from_polygon(unary_union(perimeter.geometry), custom_filter = custom_filter)
|
||||
streets = ox.graph_from_polygon(unary_union(perimeter.geometry).buffer(buffer) if buffer > 0 else unary_union(perimeter.geometry), custom_filter = custom_filter)
|
||||
streets = ox.project_graph(streets)
|
||||
streets = ox.graph_to_gdfs(streets, nodes = False)
|
||||
# Boundary defined by polygon (perimeter)
|
||||
elif (point is not None) and (radius is not None):
|
||||
# Fetch streets data, save CRS & project
|
||||
streets = ox.graph_from_point(point, dist = radius+dilate, custom_filter = custom_filter)
|
||||
streets = ox.graph_from_point(point, dist = radius+dilate+buffer, custom_filter = custom_filter)
|
||||
crs = ox.graph_to_gdfs(streets, nodes = False).crs
|
||||
streets = ox.project_graph(streets)
|
||||
# Compute perimeter from point & CRS
|
||||
|
Reference in New Issue
Block a user