logo
leafmap
3d choropleth
Initializing search
    GitHub
    GitHub
    • Home
    • Book
    • Installation
    • Get Started
    • Usage
    • Web App
    • Tutorials
    • Contributing
    • FAQ
    • Changelog
    • YouTube Channel
    • Report Issues
      • basemaps module
      • bokehmap module
      • colormaps module
      • common module
      • deck module
      • deckgl module
      • download module
      • examples module
      • foliumap module
      • kepler module
      • maplibregl module
      • leafmap module
      • legends module
      • map_widgets module
      • osm module
      • pc module
      • plot module
      • plotlymap module
      • deck module
      • stac module
      • toolbar module
      • FOSS4G 2021
      • SIGSPATIAL 2021
      • YouthMappers 2021
      • ICRW 2023
      • EarthCube 2023
      • Taiwan 2024
      • HGAC 2024
      • CVPR 2025
      • Overview
      • 3d buildings
      • 3d choropleth
      • 3d indoor mapping
      • 3d pmtiles
      • 3d style
      • 3d terrain
      • Add 3d buildings
      • Add a marker
      • Add colorbar
      • Add components
      • Add deckgl layer
      • Add gif
      • Add html
      • Add icon
      • Add image
      • Add image generated
      • Add labels
      • Add legend
      • Add logo
      • Add text
      • AlphaEarth
      • Animate a line
      • Animate camera around point
      • Animate images
      • Animate point along line
      • Animate point along route
      • Arc layer
      • Attribution position
      • Basemaps
      • Center on symbol
      • Change building color
      • Change case of labels
      • Choropleth
      • Cloud optimized geotiff
      • Cluster
      • Color switcher
      • Countries filter
      • Create vector
      • Custom marker
      • Dashboard
      • Data driven lines
      • Disable scroll zoom
      • Display rich text
      • Drag a marker
      • Draw features
      • Duckdb layer
      • Edit vector
      • Fallback image
      • Fields of the world
      • Fit bounds
      • Fill pattern
      • Floating sidebar
      • Fly to
      • Fly to options
      • Fullscreen
      • Geojson layer in stack
      • Geojson line
      • Geojson points
      • Geojson polygon
      • Geopandas
      • Globe control
      • Google earth
      • Google earth engine
      • Gps trace
      • Heatmap layer
      • Historical imagery
      • Housing prices
      • Interactive false
      • Jump to
      • Language switch
      • Layer control
      • Layer groups
      • Layer manager
      • Layer styling
      • Line gradient
      • Live geojson
      • Live update feature
      • Local geojson
      • Local raster
      • Locate user
      • Map tiles
      • Mapillary
      • Maptiler styles
      • MGRS
      • Mouse position
      • Multiple geometries
      • Nasa opera
      • Navigation
      • Ocean bathymetry
      • Openfreemap
      • Openstreetmap
      • Overture
      • Pmtiles
      • Restrict bounds
      • Satellite map
      • Search control
      • Set pitch bearing
      • Set terrain
      • Sidebar
      • Similarity search
      • Stac
      • Time slider
      • To html
      • Variable label placement
      • Variable offset label placement
      • Vector tile
      • Video on a map
      • Visualize population density
      • Wms source
      • Zoom to linestring
      • Usage
      • 01 leafmap intro
      • 02 using basemaps
      • 03 cog stac
      • 04 cog mosaic
      • 05 load raster
      • 06 legend
      • 07 colorbar
      • 08 whitebox
      • 09 csv to points
      • 10 add vector
      • 11 linked maps
      • 12 split map
      • 13 geopandas
      • 14 postgis
      • 15 openstreetmap
      • 16 heremap
      • 17 vector tile layer
      • 18 point layer
      • 19 map to html
      • 20 planet imagery
      • 21 ts inspector
      • 22 time slider
      • 23 colormaps
      • 24 heatmap
      • 25 map title
      • 26 kepler gl
      • 27 basemap gallery
      • 28 publish map
      • 29 pydeck
      • 30 census data
      • 31 search basemaps
      • 32 local tile
      • 33 image overlay
      • 34 add points from xy
      • 35 circle markers
      • 36 add labels
      • 37 planetary computer
      • 38 plotly
      • 39 inspector tool
      • 40 plotly gui
      • 41 raster gui
      • 42 create cog
      • 43 search control
      • 44 attribute table
      • 45 create vector
      • 46 edit vector
      • 47 numpy to cog
      • 48 lidar
      • 49 split control
      • 50 marker cluster
      • 51 clip image
      • 52 netcdf
      • 53 choropleth
      • 54 plot raster
      • 55 lidar
      • 56 download ned
      • 57 national map
      • 58 bokeh
      • 59 create legend
      • 60 add widget
      • 61 vector to gif
      • 62 folium colorbar
      • 63 arcgis
      • 64 stac search
      • 65 sagemaker
      • 66 gradio
      • 67 maxar open data
      • 68 openaerialmap
      • 69 turkey earthquake
      • 70 zonal stats
      • 71 aws s3
      • 72 timelapse
      • 73 custom stac
      • 74 map tiles to geotiff
      • 75 segment anything
      • 76 image comparison
      • 77 split raster
      • 78 read raster
      • 79 timeseries
      • 80 solar
      • 81 buildings
      • 82 pmtiles
      • 83 vector viz
      • 84 read parquet
      • 85 gedi
      • 86 add markers
      • 87 actinia
      • 88 nasa earth data
      • 89 image array viz
      • 90 pixel inspector
      • 91 raster viz gui
      • 92 maplibre
      • 93 maplibre pmtiles
      • 94 mapbox
      • 95 edit vector
      • 96 batch edit vector
      • 97 overture data
      • 98 watershed
      • 99 wetlands
      • 100 nlcd
      • 101 nasa opera
      • 102 fused
      • 103 raster colormap
      • 104 point style
      • 105 vector time slider
      • 106 aws s3

    image image image

    Create a 3D choropleth map of Europe with countries extruded

    This source code of this example is adapted from the MapTiler SDK JS example - Create a 3D choropleth map of Europe with countries extruded.

    Uncomment the following line to install leafmap if needed.

    In [1]:
    Copied!
    # %pip install "leafmap[maplibre]"
    
    # %pip install "leafmap[maplibre]"
    In [2]:
    Copied!
    import leafmap.maplibregl as leafmap
    
    import leafmap.maplibregl as leafmap

    To run this notebook, you will need an API key from MapTiler. Once you have the API key, you can uncomment the following code block and replace YOUR_API_KEY with your actual API key. Then, run the code block code to set the API key as an environment variable.

    In [3]:
    Copied!
    # import os
    # os.environ["MAPTILER_KEY"] = "YOUR_API_KEY"
    
    # import os # os.environ["MAPTILER_KEY"] = "YOUR_API_KEY"
    In [4]:
    Copied!
    m = leafmap.Map(center=[19.43, 49.49], zoom=3, pitch=60, style="basic")
    source = {
        "type": "geojson",
        "data": "https://docs.maptiler.com/sdk-js/assets/Mean_age_of_women_at_first_marriage_in_2019.geojson",
    }
    m.add_source("countries", source)
    layer = {
        "id": "eu-countries",
        "source": "countries",
        "type": "fill-extrusion",
        "paint": {
            "fill-extrusion-color": [
                "interpolate",
                ["linear"],
                ["get", "age"],
                23.0,
                "#fff5eb",
                24.0,
                "#fee6ce",
                25.0,
                "#fdd0a2",
                26.0,
                "#fdae6b",
                27.0,
                "#fd8d3c",
                28.0,
                "#f16913",
                29.0,
                "#d94801",
                30.0,
                "#8c2d04",
            ],
            "fill-extrusion-opacity": 1,
            "fill-extrusion-height": ["*", ["get", "age"], 5000],
        },
    }
    first_symbol_layer_id = m.find_first_symbol_layer()["id"]
    m.add_layer(layer, first_symbol_layer_id)
    m.add_layer_control()
    m
    
    m = leafmap.Map(center=[19.43, 49.49], zoom=3, pitch=60, style="basic") source = { "type": "geojson", "data": "https://docs.maptiler.com/sdk-js/assets/Mean_age_of_women_at_first_marriage_in_2019.geojson", } m.add_source("countries", source) layer = { "id": "eu-countries", "source": "countries", "type": "fill-extrusion", "paint": { "fill-extrusion-color": [ "interpolate", ["linear"], ["get", "age"], 23.0, "#fff5eb", 24.0, "#fee6ce", 25.0, "#fdd0a2", 26.0, "#fdae6b", 27.0, "#fd8d3c", 28.0, "#f16913", 29.0, "#d94801", 30.0, "#8c2d04", ], "fill-extrusion-opacity": 1, "fill-extrusion-height": ["*", ["get", "age"], 5000], }, } first_symbol_layer_id = m.find_first_symbol_layer()["id"] m.add_layer(layer, first_symbol_layer_id) m.add_layer_control() m
    In [5]:
    Copied!
    m = leafmap.Map(center=[-100, 40], zoom=3, pitch=60, style="basic")
    source = {
        "type": "geojson",
        "data": "https://opengeos.org/data/us/us_counties.geojson",
    }
    m.add_source("counties", source)
    layer = {
        "id": "us-counties",
        "source": "counties",
        "type": "fill-extrusion",
        "paint": {
            "fill-extrusion-color": [
                "interpolate",
                ["linear"],
                ["get", "CENSUSAREA"],
                400,
                "#fff5eb",
                600,
                "#fee6ce",
                800,
                "#fdd0a2",
                1000,
                "#fdae6b",
            ],
            "fill-extrusion-opacity": 1,
            "fill-extrusion-height": ["*", ["get", "CENSUSAREA"], 50],
        },
    }
    first_symbol_layer_id = m.find_first_symbol_layer()["id"]
    m.add_layer(layer, first_symbol_layer_id)
    m.add_layer_control()
    m
    
    m = leafmap.Map(center=[-100, 40], zoom=3, pitch=60, style="basic") source = { "type": "geojson", "data": "https://opengeos.org/data/us/us_counties.geojson", } m.add_source("counties", source) layer = { "id": "us-counties", "source": "counties", "type": "fill-extrusion", "paint": { "fill-extrusion-color": [ "interpolate", ["linear"], ["get", "CENSUSAREA"], 400, "#fff5eb", 600, "#fee6ce", 800, "#fdd0a2", 1000, "#fdae6b", ], "fill-extrusion-opacity": 1, "fill-extrusion-height": ["*", ["get", "CENSUSAREA"], 50], }, } first_symbol_layer_id = m.find_first_symbol_layer()["id"] m.add_layer(layer, first_symbol_layer_id) m.add_layer_control() m

    2025-02-23 2024-06-19
    Copyright © 2021 - 2024 Qiusheng Wu
    Made with Material for MkDocs