solara-geemap / pages /01_basic.py
giswqs's picture
Add notebook examples (#2)
02c996d unverified
import geemap
import solara
zoom = solara.reactive(4)
center = solara.reactive((40, -100))
bounds = solara.reactive(None)
@solara.component
def Page():
# Isolation is required to prevent the map from overlapping navigation (when screen width < 960px)
with solara.Column(
style={"min-width": "500px", "height": "780px", "isolation": "isolate"}
):
# solara components support reactive variables
solara.SliderInt(label="Zoom level", value=zoom, min=1, max=20)
# using 3rd party widget library require wiring up the events manually
# using zoom.value and zoom.set
geemap.Map.element( # type: ignore
zoom=zoom.value,
on_zoom=zoom.set,
center=center.value,
on_center=center.set,
on_bounds=bounds.set,
scroll_wheel_zoom=True,
height="600px",
)
solara.Text(f"Zoom: {zoom.value}")
solara.Text(f"Center: {center.value}")
solara.Text(f"Bounds: {bounds.value}")