22 time slider
Using time slider for visualizing timeseries images
Uncomment the following line to install leafmap if needed.
In [1]:
Copied!
# !pip install leafmap
# !pip install leafmap
This notebook requires the ipyleaflet plotting backend. Folium is not supported.
In [2]:
Copied!
from leafmap import leafmap
from leafmap import leafmap
First, you need to sign up a Planet account and get an API key. See https://developers.planet.com/quickstart/apis. Uncomment the following line to pass in your API key.
In [3]:
Copied!
# os.environ["PLANET_API_KEY"] = "12345"
# os.environ["PLANET_API_KEY"] = "12345"
Specify the map center and zoom level.
In [4]:
Copied!
m = leafmap.Map(center=[38.2659, -103.2447], zoom=13)
m
m = leafmap.Map(center=[38.2659, -103.2447], zoom=13)
m
Use the time slider to visualize Planet quarterly mosaic.
In [5]:
Copied!
m = leafmap.Map()
layers_dict = leafmap.planet_quarterly_tiles()
m.add_time_slider(layers_dict, time_interval=1)
m
m = leafmap.Map()
layers_dict = leafmap.planet_quarterly_tiles()
m.add_time_slider(layers_dict, time_interval=1)
m
Use the time slider to visualize basemaps.
In [6]:
Copied!
m = leafmap.Map()
m.clear_layers()
layers_dict = leafmap.basemap_xyz_tiles()
m.add_time_slider(layers_dict, time_interval=1)
m
m = leafmap.Map()
m.clear_layers()
layers_dict = leafmap.basemap_xyz_tiles()
m.add_time_slider(layers_dict, time_interval=1)
m
Use the time slider to visualize COG assets found within STAC items.
In [7]:
Copied!
import ipyleaflet
import json
import requests
stac_api = "https://earth-search.aws.element84.com/v0"
search_endpoint = f"{stac_api}/search"
collection = "sentinel-s2-l2a-cogs"
payload = {
"bbox": [
-102.83340454101562,
49.77860375256143,
-102.41043090820312,
50.05273014900257,
],
"datetime": "2021-07-01T00:00:00Z/2021-10-01T12:31:12Z",
"collections": [collection],
"limit": 10,
"query": {"eo:cloud_cover": {"gte": 0, "lte": 10}},
}
headers = {"Content-Type": "application/json"}
response = requests.request(
"POST", search_endpoint, headers=headers, data=json.dumps(payload)
)
features = response.json()["features"]
features.sort(key=lambda x: x["properties"]["datetime"], reverse=False)
layers_dict = {}
for feature in features:
feature_id = feature["id"]
print(feature_id)
url = leafmap.stac_tile(
f"{stac_api}/collections/{collection}/items/{feature_id}", bands=["visual"]
)
tile_layer = ipyleaflet.TileLayer(
url=url,
name=feature_id,
)
layers_dict[feature_id] = tile_layer
m = leafmap.Map(center=[50.093079, -103.152825], zoom=11)
m.add_time_slider(layers_dict, time_interval=2)
m
import ipyleaflet
import json
import requests
stac_api = "https://earth-search.aws.element84.com/v0"
search_endpoint = f"{stac_api}/search"
collection = "sentinel-s2-l2a-cogs"
payload = {
"bbox": [
-102.83340454101562,
49.77860375256143,
-102.41043090820312,
50.05273014900257,
],
"datetime": "2021-07-01T00:00:00Z/2021-10-01T12:31:12Z",
"collections": [collection],
"limit": 10,
"query": {"eo:cloud_cover": {"gte": 0, "lte": 10}},
}
headers = {"Content-Type": "application/json"}
response = requests.request(
"POST", search_endpoint, headers=headers, data=json.dumps(payload)
)
features = response.json()["features"]
features.sort(key=lambda x: x["properties"]["datetime"], reverse=False)
layers_dict = {}
for feature in features:
feature_id = feature["id"]
print(feature_id)
url = leafmap.stac_tile(
f"{stac_api}/collections/{collection}/items/{feature_id}", bands=["visual"]
)
tile_layer = ipyleaflet.TileLayer(
url=url,
name=feature_id,
)
layers_dict[feature_id] = tile_layer
m = leafmap.Map(center=[50.093079, -103.152825], zoom=11)
m.add_time_slider(layers_dict, time_interval=2)
m
S2A_13UFR_20210710_0_L2A
S2B_13UFR_20210715_0_L2A
S2B_13UFR_20210718_0_L2A
S2A_13UFR_20210723_0_L2A S2B_13UFR_20210725_0_L2A
S2A_13UFR_20210730_0_L2A
S2B_13UFR_20210814_0_L2A S2A_13UFR_20210908_0_L2A
S2A_13UFR_20210918_0_L2A
S2A_13UFR_20210928_0_L2A