Add initial test for rendering buildings
This commit is contained in:
parent
5da9766da6
commit
4b32d72f8f
|
@ -1,5 +1,21 @@
|
|||
import tkinter
|
||||
import tkintermapview
|
||||
import json
|
||||
import copy
|
||||
|
||||
with open('./data/collinear_clean.geojson', 'r') as city_file:
|
||||
city = json.load(city_file)
|
||||
buildings = city['features']
|
||||
|
||||
building_polygons = []
|
||||
|
||||
for building in buildings:
|
||||
building_polygon = []
|
||||
if building['geometry']['type'] == 'Polygon':
|
||||
for coordinate in building['geometry']['coordinates'][0]:
|
||||
building_polygon.append((coordinate[1], coordinate[0]))
|
||||
building_polygons.append({'id': building['id'],
|
||||
'polygon': copy.deepcopy(building_polygon)})
|
||||
|
||||
# create tkinter window
|
||||
root_tk = tkinter.Tk()
|
||||
|
@ -15,7 +31,7 @@ map_widget.set_tile_server("https://mt0.google.com/vt/lyrs=m&hl=en&x={x}&y={y}&z
|
|||
# map_widget.set_tile_server("https://mt0.google.com/vt/lyrs=s&hl=en&x={x}&y={y}&z={z}&s=Ga", max_zoom=22) # google satellite
|
||||
|
||||
# set current position and zoom
|
||||
map_widget.set_position(45.497059, -73.578451, marker=False) # Berlin, Germany
|
||||
map_widget.set_position(45.497059, -73.578451, marker=False) # Montreal, Quebec
|
||||
map_widget.set_zoom(11)
|
||||
|
||||
# set current position with address
|
||||
|
@ -24,4 +40,15 @@ map_widget.set_zoom(11)
|
|||
def marker_click(marker):
|
||||
print(f"marker clicked - text: {marker.text} position: {marker.position}")
|
||||
|
||||
building_polygon_markers = []
|
||||
count = 0
|
||||
for building_polygon in building_polygons:
|
||||
if count > 1000:
|
||||
break
|
||||
building_polygon_markers.append(map_widget.set_polygon(building_polygon['polygon'],
|
||||
fill_color='black',
|
||||
outline_color='black',
|
||||
name=building_polygon['id']))
|
||||
count+=1
|
||||
|
||||
root_tk.mainloop()
|
Loading…
Reference in New Issue
Block a user