geosdemo module¶
Main module.
Map (Map)
¶
Source code in geosdemo/geosdemo.py
class Map(ipyleaflet.Map):
def __init__(self, center=[20, 0], zoom=2, **kwargs) -> None:
if "scroll_wheel_zoom" not in kwargs:
kwargs["scroll_wheel_zoom"] = True
super().__init__(center=center, zoom=zoom, **kwargs)
if "layers_control" not in kwargs:
kwargs["layers_control"] = True
if kwargs["layers_control"]:
self.add_layers_control()
if "fullscreen_control" not in kwargs:
kwargs["fullscreen_control"] = True
if kwargs["fullscreen_control"]:
self.add_fullscreen_control()
if "height" in kwargs:
self.layout.height = kwargs["height"]
else:
self.layout.height = "600px"
def add_search_control(self, position="topleft", **kwargs):
"""Adds a search control to the map.
Args:
kwargs: Keyword arguments to pass to the search control.
"""
if "url" not in kwargs:
kwargs["url"] = 'https://nominatim.openstreetmap.org/search?format=json&q={s}'
search_control = ipyleaflet.SearchControl(position=position, **kwargs)
self.add_control(search_control)
def add_draw_control(self, **kwargs):
"""Adds a draw control to the map.
Args:
kwargs: Keyword arguments to pass to the draw control.
"""
draw_control = ipyleaflet.DrawControl(**kwargs)
draw_control.polyline = {
"shapeOptions": {
"color": "#6bc2e5",
"weight": 8,
"opacity": 1.0
}
}
draw_control.polygon = {
"shapeOptions": {
"fillColor": "#6be5c3",
"color": "#6be5c3",
"fillOpacity": 1.0
},
"drawError": {
"color": "#dd253b",
"message": "Oups!"
},
"allowIntersection": False
}
draw_control.circle = {
"shapeOptions": {
"fillColor": "#efed69",
"color": "#efed69",
"fillOpacity": 1.0
}
}
draw_control.rectangle = {
"shapeOptions": {
"fillColor": "#fca45d",
"color": "#fca45d",
"fillOpacity": 1.0
}
}
self.add_control(draw_control)
def add_layers_control(self, position='topright'):
"""Adds a layers control to the map.
Args:
kwargs: Keyword arguments to pass to the layers control.
"""
layers_control = ipyleaflet.LayersControl(position=position)
self.add_control(layers_control)
def add_fullscreen_control(self, position="topleft"):
"""Adds a fullscreen control to the map.
Args:
kwargs: Keyword arguments to pass to the fullscreen control.
"""
fullscreen_control = ipyleaflet.FullScreenControl(position=position)
self.add_control(fullscreen_control)
def add_tile_layer(self, url, name, attribution="", **kwargs):
"""Adds a tile layer to the map.
Args:
url (str): The URL of the tile layer.
name (str): The name of the tile layer.
attribution (str, optional): The attribution of the tile layer. Defaults to "".
"""
tile_layer = ipyleaflet.TileLayer(
url=url,
name=name,
attribution=attribution,
**kwargs
)
self.add_layer(tile_layer)
def add_basemap(self, basemap, **kwargs):
import xyzservices.providers as xyz
if basemap.lower() == "roadmap":
url = 'http://mt0.google.com/vt/lyrs=m&hl=en&x={x}&y={y}&z={z}'
self.add_tile_layer(url, name=basemap, **kwargs)
elif basemap.lower() == "satellite":
url = 'http://mt0.google.com/vt/lyrs=y&hl=en&x={x}&y={y}&z={z}'
self.add_tile_layer(url, name=basemap, **kwargs)
else:
try:
basemap = eval(f"xyz.{basemap}")
url = basemap.build_url()
attribution = basemap.attribution
self.add_tile_layer(url, name=basemap.name, attribution=attribution, **kwargs)
except:
raise ValueError(f"Basemap '{basemap}' not found.")
def add_geojson(self, data, name='GeoJSON', **kwargs):
"""Adds a GeoJSON layer to the map.
Args:
data (dict): The GeoJSON data.
"""
if isinstance(data, str):
import json
with open(data, "r") as f:
data = json.load(f)
geojson = ipyleaflet.GeoJSON(data=data,name=name, **kwargs)
self.add_layer(geojson)
def add_shp(self, data, name='Shapefile', **kwargs):
"""Adds a Shapefile layer to the map.
Args:
data (str): The path to the Shapefile.
"""
import geopandas as gpd
gdf = gpd.read_file(data)
geojson = gdf.__geo_interface__
self.add_geojson(geojson, name=name, **kwargs)
def add_geojson(self, data, **kwargs):
"""Adds a GeoJSON layer to the map.
Args:
data (dict): The GeoJSON data.
kwargs: Keyword arguments to pass to the GeoJSON layer.
"""
import json
if isinstance(data, str):
with open(data, "r") as f:
data = json.load(f)
geojson = ipyleaflet.GeoJSON(data=data, **kwargs)
self.add_layer(geojson)
def add_raster(self, url, name='Raster', fit_bounds=True, **kwargs):
"""Adds a raster layer to the map.
Args:
url (str): The URL of the raster layer.
name (str, optional): The name of the raster layer. Defaults to 'Raster'.
fit_bounds (bool, optional): Whether to fit the map bounds to the raster layer. Defaults to True.
"""
import httpx
titiler_endpoint = "https://titiler.xyz"
r = httpx.get(
f"{titiler_endpoint}/cog/info",
params = {
"url": url,
}
).json()
bounds = r["bounds"]
r = httpx.get(
f"{titiler_endpoint}/cog/tilejson.json",
params = {
"url": url,
}
).json()
tile = r["tiles"][0]
self.add_tile_layer(url=tile, name=name, **kwargs)
if fit_bounds:
bbox = [[bounds[1], bounds[0]], [bounds[3], bounds[2]]]
self.fit_bounds(bbox)
def add_toolbar(self, position="topright"):
widget_width = "250px"
padding = "0px 0px 0px 5px" # upper, right, bottom, left
toolbar_button = widgets.ToggleButton(
value=False,
tooltip="Toolbar",
icon="wrench",
layout=widgets.Layout(width="28px", height="28px", padding=padding),
)
close_button = widgets.ToggleButton(
value=False,
tooltip="Close the tool",
icon="times",
button_style="primary",
layout=widgets.Layout(height="28px", width="28px", padding=padding),
)
toolbar = widgets.HBox([toolbar_button])
def toolbar_click(change):
if change["new"]:
toolbar.children = [toolbar_button, close_button]
else:
toolbar.children = [toolbar_button]
toolbar_button.observe(toolbar_click, "value")
def close_click(change):
if change["new"]:
toolbar_button.close()
close_button.close()
toolbar.close()
close_button.observe(close_click, "value")
rows = 2
cols = 2
grid = widgets.GridspecLayout(rows, cols, grid_gap="0px", layout=widgets.Layout(width="65px"))
icons = ["folder-open", "map", "bluetooth", "area-chart"]
for i in range(rows):
for j in range(cols):
grid[i, j] = widgets.Button(description="", button_style="primary", icon=icons[i*rows+j],
layout=widgets.Layout(width="28px", padding="0px"))
toolbar = widgets.VBox([toolbar_button])
def toolbar_click(change):
if change["new"]:
toolbar.children = [widgets.HBox([close_button, toolbar_button]), grid]
else:
toolbar.children = [toolbar_button]
toolbar_button.observe(toolbar_click, "value")
toolbar_ctrl = ipyleaflet.WidgetControl(widget=toolbar, position=position)
self.add_control(toolbar_ctrl)
add_draw_control(self, **kwargs)
¶
Adds a draw control to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
kwargs |
Keyword arguments to pass to the draw control. |
{} |
Source code in geosdemo/geosdemo.py
def add_draw_control(self, **kwargs):
"""Adds a draw control to the map.
Args:
kwargs: Keyword arguments to pass to the draw control.
"""
draw_control = ipyleaflet.DrawControl(**kwargs)
draw_control.polyline = {
"shapeOptions": {
"color": "#6bc2e5",
"weight": 8,
"opacity": 1.0
}
}
draw_control.polygon = {
"shapeOptions": {
"fillColor": "#6be5c3",
"color": "#6be5c3",
"fillOpacity": 1.0
},
"drawError": {
"color": "#dd253b",
"message": "Oups!"
},
"allowIntersection": False
}
draw_control.circle = {
"shapeOptions": {
"fillColor": "#efed69",
"color": "#efed69",
"fillOpacity": 1.0
}
}
draw_control.rectangle = {
"shapeOptions": {
"fillColor": "#fca45d",
"color": "#fca45d",
"fillOpacity": 1.0
}
}
self.add_control(draw_control)
add_fullscreen_control(self, position='topleft')
¶
Adds a fullscreen control to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
kwargs |
Keyword arguments to pass to the fullscreen control. |
required |
Source code in geosdemo/geosdemo.py
def add_fullscreen_control(self, position="topleft"):
"""Adds a fullscreen control to the map.
Args:
kwargs: Keyword arguments to pass to the fullscreen control.
"""
fullscreen_control = ipyleaflet.FullScreenControl(position=position)
self.add_control(fullscreen_control)
add_geojson(self, data, **kwargs)
¶
Adds a GeoJSON layer to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
data |
dict |
The GeoJSON data. |
required |
kwargs |
Keyword arguments to pass to the GeoJSON layer. |
{} |
Source code in geosdemo/geosdemo.py
def add_geojson(self, data, **kwargs):
"""Adds a GeoJSON layer to the map.
Args:
data (dict): The GeoJSON data.
kwargs: Keyword arguments to pass to the GeoJSON layer.
"""
import json
if isinstance(data, str):
with open(data, "r") as f:
data = json.load(f)
geojson = ipyleaflet.GeoJSON(data=data, **kwargs)
self.add_layer(geojson)
add_layers_control(self, position='topright')
¶
Adds a layers control to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
kwargs |
Keyword arguments to pass to the layers control. |
required |
Source code in geosdemo/geosdemo.py
def add_layers_control(self, position='topright'):
"""Adds a layers control to the map.
Args:
kwargs: Keyword arguments to pass to the layers control.
"""
layers_control = ipyleaflet.LayersControl(position=position)
self.add_control(layers_control)
add_raster(self, url, name='Raster', fit_bounds=True, **kwargs)
¶
Adds a raster layer to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
url |
str |
The URL of the raster layer. |
required |
name |
str |
The name of the raster layer. Defaults to 'Raster'. |
'Raster' |
fit_bounds |
bool |
Whether to fit the map bounds to the raster layer. Defaults to True. |
True |
Source code in geosdemo/geosdemo.py
def add_raster(self, url, name='Raster', fit_bounds=True, **kwargs):
"""Adds a raster layer to the map.
Args:
url (str): The URL of the raster layer.
name (str, optional): The name of the raster layer. Defaults to 'Raster'.
fit_bounds (bool, optional): Whether to fit the map bounds to the raster layer. Defaults to True.
"""
import httpx
titiler_endpoint = "https://titiler.xyz"
r = httpx.get(
f"{titiler_endpoint}/cog/info",
params = {
"url": url,
}
).json()
bounds = r["bounds"]
r = httpx.get(
f"{titiler_endpoint}/cog/tilejson.json",
params = {
"url": url,
}
).json()
tile = r["tiles"][0]
self.add_tile_layer(url=tile, name=name, **kwargs)
if fit_bounds:
bbox = [[bounds[1], bounds[0]], [bounds[3], bounds[2]]]
self.fit_bounds(bbox)
add_search_control(self, position='topleft', **kwargs)
¶
Adds a search control to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
kwargs |
Keyword arguments to pass to the search control. |
{} |
Source code in geosdemo/geosdemo.py
def add_search_control(self, position="topleft", **kwargs):
"""Adds a search control to the map.
Args:
kwargs: Keyword arguments to pass to the search control.
"""
if "url" not in kwargs:
kwargs["url"] = 'https://nominatim.openstreetmap.org/search?format=json&q={s}'
search_control = ipyleaflet.SearchControl(position=position, **kwargs)
self.add_control(search_control)
add_shp(self, data, name='Shapefile', **kwargs)
¶
Adds a Shapefile layer to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
data |
str |
The path to the Shapefile. |
required |
Source code in geosdemo/geosdemo.py
def add_shp(self, data, name='Shapefile', **kwargs):
"""Adds a Shapefile layer to the map.
Args:
data (str): The path to the Shapefile.
"""
import geopandas as gpd
gdf = gpd.read_file(data)
geojson = gdf.__geo_interface__
self.add_geojson(geojson, name=name, **kwargs)
add_tile_layer(self, url, name, attribution='', **kwargs)
¶
Adds a tile layer to the map.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
url |
str |
The URL of the tile layer. |
required |
name |
str |
The name of the tile layer. |
required |
attribution |
str |
The attribution of the tile layer. Defaults to "". |
'' |
Source code in geosdemo/geosdemo.py
def add_tile_layer(self, url, name, attribution="", **kwargs):
"""Adds a tile layer to the map.
Args:
url (str): The URL of the tile layer.
name (str): The name of the tile layer.
attribution (str, optional): The attribution of the tile layer. Defaults to "".
"""
tile_layer = ipyleaflet.TileLayer(
url=url,
name=name,
attribution=attribution,
**kwargs
)
self.add_layer(tile_layer)
generate_lucky_number(length=1)
¶
Generates a random number of a given length.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
length |
int |
The length of the number to generate. Defaults to 1. |
1 |
Returns:
Type | Description |
---|---|
int |
The generated number. |
Source code in geosdemo/geosdemo.py
def generate_lucky_number(length=1):
"""Generates a random number of a given length.
Args:
length (int, optional): The length of the number to generate. Defaults to 1.
Returns:
int: The generated number.
"""
result_str = ''.join(random.choice(string.digits) for i in range(length))
return int(result_str)
generate_random_string(length=10, upper=False, digits=False, punctuation=False)
¶
Generates a random string of a given length.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
length |
int |
The length of the string to generate. Defaults to 10. |
10 |
upper |
bool |
Whether to include uppercase letters. Defaults to False. |
False |
digits |
bool |
Whether to include digits. Defaults to False. |
False |
punctuation |
bool |
Whether to include punctuation. Defaults to False. |
False |
Returns:
Type | Description |
---|---|
str |
The generated string. |
Source code in geosdemo/geosdemo.py
def generate_random_string(length=10, upper=False, digits=False, punctuation=False):
"""Generates a random string of a given length.
Args:
length (int, optional): The length of the string to generate. Defaults to 10.
upper (bool, optional): Whether to include uppercase letters. Defaults to False.
digits (bool, optional): Whether to include digits. Defaults to False.
punctuation (bool, optional): Whether to include punctuation. Defaults to False.
Returns:
str: The generated string.
"""
letters = string.ascii_lowercase
if upper:
letters += string.ascii_uppercase
if digits:
letters += string.digits
if punctuation:
letters += string.punctuation
result_str = ''.join(random.choice(letters) for i in range(length))
return result_str