Skip to content

Commit

Permalink
Add support for publishing maps #109
Browse files Browse the repository at this point in the history
  • Loading branch information
giswqs committed Jul 5, 2020
1 parent c9c51be commit 086230e
Show file tree
Hide file tree
Showing 4 changed files with 261 additions and 10 deletions.
8 changes: 8 additions & 0 deletions README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@ Below is a partial list of features available for the geemap package. Please che
* Exporting Earth Engine maps as HTML files and PNG images.
* Searching Earth Engine API documentation within Jupyter notebooks.
* Importing Earth Engine assets from personal account.
# Publishing interactive GEE maps directly within Jupyter notebook.


Installation
Expand Down Expand Up @@ -423,6 +424,13 @@ To search Earth Engine API documentation with Jupyter notebooks:
geemap.ee_search()
To publish an interactive GEE map with Jupyter notebooks:

.. code:: python
Map.publish(name, headline, visibility)
Examples
--------
Expand Down
189 changes: 189 additions & 0 deletions examples/notebooks/24_publish_maps.ipynb
Original file line number Diff line number Diff line change
@@ -0,0 +1,189 @@
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"To follow this tutorial, you will need to [sign up](https://datapane.com/accounts/signup/) for an account with <https://datapane.com>, then install and authenticate the `datapane` Python package. More information can be found [here](https://docs.datapane.com/tutorials/tut-getting-started). \n",
"\n",
"- `pip install datapane`\n",
"- `datapane login`\n",
"- `datapane ping`"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"import ee \n",
"import geemap.eefolium as geemap"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [],
"source": [
"# Create a map centered at (lat, lon).\n",
"Map = geemap.Map(center=[40, -100], zoom=4)\n",
"\n",
"# Use an elevation dataset and terrain functions to create\n",
"# a custom visualization of topography.\n",
"\n",
"# Load a global elevation image.\n",
"elev = ee.Image('USGS/GMTED2010')\n",
"\n",
"# Zoom to an area of interest.\n",
"Map.setCenter(-121.069, 50.709, 6)\n",
"\n",
"# Add the elevation to the map.\n",
"Map.addLayer(elev, {}, 'elev')\n",
"\n",
"# Use the terrain algorithms to compute a hillshade with 8-bit values.\n",
"shade = ee.Terrain.hillshade(elev)\n",
"Map.addLayer(shade, {}, 'hillshade', False)\n",
"\n",
"# Create a \"sea\" variable to be used for cartographic purposes\n",
"sea = elev.lte(0)\n",
"Map.addLayer(sea.mask(sea), {'palette':'000022'}, 'sea', False)\n",
"\n",
"# Create a custom elevation palette from hex strings.\n",
"elevationPalette = ['006600', '002200', 'fff700', 'ab7634', 'c4d0ff', 'ffffff']\n",
"# Use these visualization parameters, customized by location.\n",
"visParams = {'min': 1, 'max': 3000, 'palette': elevationPalette}\n",
"\n",
"# Create a mosaic of the sea and the elevation data\n",
"visualized = ee.ImageCollection([\n",
" # Mask the elevation to get only land\n",
" elev.mask(sea.Not()).visualize(**visParams),\n",
" # Use the sea mask directly to display sea.\n",
" sea.mask(sea).visualize(**{'palette':'000022'})\n",
"]).mosaic()\n",
"\n",
"# Note that the visualization image doesn't require visualization parameters.\n",
"Map.addLayer(visualized, {}, 'elev palette', False)\n",
"\n",
"# Convert the visualized elevation to HSV, first converting to [0, 1] data.\n",
"hsv = visualized.divide(255).rgbToHsv()\n",
"# Select only the hue and saturation bands.\n",
"hs = hsv.select(0, 1)\n",
"# Convert the hillshade to [0, 1] data, as expected by the HSV algorithm.\n",
"v = shade.divide(255)\n",
"# Create a visualization image by converting back to RGB from HSV.\n",
"# Note the cast to byte in order to export the image correctly.\n",
"rgb = hs.addBands(v).hsvToRgb().multiply(255).byte()\n",
"Map.addLayer(rgb, {}, 'styled')\n",
"\n",
"states = ee.FeatureCollection('TIGER/2018/States')\n",
"Map.addLayer(ee.Image().paint(states, 0, 2), {}, \"US States\")"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div style=\"width:100%;\"><div style=\"position:relative;width:100%;height:0;padding-bottom:60%;\"><iframe src=\"data:text/html;charset=utf-8;base64,<!DOCTYPE html>
<head>    
    <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
    
        <script>
            L_NO_TOUCH = false;
            L_DISABLE_3D = false;
        </script>
    
    <script src="https://cdn.jsdelivr.net/npm/leaflet@1.6.0/dist/leaflet.js"></script>
    <script src="https://code.jquery.com/jquery-1.12.4.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/leaflet@1.6.0/dist/leaflet.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap-theme.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css"/>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.css"/>
    <link rel="stylesheet" href="https://rawcdn.githack.com/python-visualization/folium/master/folium/templates/leaflet.awesome.rotate.css"/>
    <style>html, body {width: 100%;height: 100%;margin: 0;padding: 0;}</style>
    <style>#map {position:absolute;top:0;bottom:0;right:0;left:0;}</style>
    
            <meta name="viewport" content="width=device-width,
                initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
            <style>
                #map_60cd5cbebfbc446293ec6e680728c9a6 {
                    position: relative;
                    width: 100.0%;
                    height: 100.0%;
                    left: 0.0%;
                    top: 0.0%;
                }
            </style>
        
    <script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet.fullscreen/1.4.2/Control.FullScreen.min.js"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet.fullscreen/1.4.2/Control.FullScreen.min.css"/>
</head>
<body>    
    
            <div class="folium-map" id="map_60cd5cbebfbc446293ec6e680728c9a6" ></div>
        
</body>
<script>    
    
            var map_60cd5cbebfbc446293ec6e680728c9a6 = L.map(
                "map_60cd5cbebfbc446293ec6e680728c9a6",
                {
                    center: [40.0, -100.0],
                    crs: L.CRS.EPSG3857,
                    zoom: 4,
                    zoomControl: true,
                    preferCanvas: false,
                    addGoogleMap: true,
                }
            );

            

        
    
            var tile_layer_ccd70ad8174c479fa06bafe3bc9a316d = L.tileLayer(
                "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",
                {"attribution": "Data by \u0026copy; \u003ca href=\"http://openstreetmap.org\"\u003eOpenStreetMap\u003c/a\u003e, under \u003ca href=\"http://www.openstreetmap.org/copyright\"\u003eODbL\u003c/a\u003e.", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_ae26ed257869480f888ac4d0a6db1c1c = L.tileLayer(
                "https://mt1.google.com/vt/lyrs=m\u0026x={x}\u0026y={y}\u0026z={z}",
                {"attribution": "Google", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
                var lat_lng_popup_1dcc5ff909b74183beb1c90e66fb1fc5 = L.popup();
                function latLngPop(e) {
                    lat_lng_popup_1dcc5ff909b74183beb1c90e66fb1fc5
                        .setLatLng(e.latlng)
                        .setContent("Latitude: " + e.latlng.lat.toFixed(4) +
                                    "<br>Longitude: " + e.latlng.lng.toFixed(4))
                        .openOn(map_60cd5cbebfbc446293ec6e680728c9a6);
                    }
                map_60cd5cbebfbc446293ec6e680728c9a6.on('click', latLngPop);
            
    
            map_60cd5cbebfbc446293ec6e680728c9a6.fitBounds(
                [[40, -100], [40, -100]],
                {"maxZoom": 4}
            );
        
    
            map_60cd5cbebfbc446293ec6e680728c9a6.fitBounds(
                [[50.709, -121.069], [50.709, -121.069]],
                {"maxZoom": 6}
            );
        
    
            var tile_layer_aa8d2b876efa410d928a9cf146efbc88 = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/55021e580ec5c318560185d6bbb89fa1-d87bde53566b12e3b4432d7b30045adb/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_402b4dec6b92451b9dcdee6d31e9695f = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/e5dd9e70efb5dc141e9a546948730fde-2e84d65cc8850f88b9e4855f38db79b1/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_2d40bee1a9454f8db0dfb853cb7848d1 = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/65ac6f07ae50696fe6b01378969c0398-36a406bf59e2ff2878a4e50f882e324c/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_0fab0314b6524eea81cdded83c5b369a = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/22b4e8067f61f42903afef2b327d8c06-fd0e261a3afa3c27d3a4d3007b711982/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_12f682c267e8409eb3cf863f8aba91d6 = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/d21ca558e7e26c1c7cf1a5b39e63e3f6-a9afa8897130c9aceb36d5920dde31d1/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var tile_layer_a1486c62d70a4ff78379f36fc29debb7 = L.tileLayer(
                "https://earthengine.googleapis.com/v1alpha/projects/earthengine-legacy/maps/a6f77aeb181cb5d4740c338446a88a70-931f9d8ff6f178b67963d51a296e4882/tiles/{z}/{x}/{y}",
                {"attribution": "Google Earth Engine", "detectRetina": false, "maxNativeZoom": 18, "maxZoom": 18, "minZoom": 0, "noWrap": false, "opacity": 1.0, "subdomains": "abc", "tms": false}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
            var layer_control_58c2534d289141ad81460d22b9a88901 = {
                base_layers : {
                    "openstreetmap" : tile_layer_ccd70ad8174c479fa06bafe3bc9a316d,
                },
                overlays :  {
                    "Google Maps" : tile_layer_ae26ed257869480f888ac4d0a6db1c1c,
                    "elev" : tile_layer_aa8d2b876efa410d928a9cf146efbc88,
                    "hillshade" : tile_layer_402b4dec6b92451b9dcdee6d31e9695f,
                    "sea" : tile_layer_2d40bee1a9454f8db0dfb853cb7848d1,
                    "elev palette" : tile_layer_0fab0314b6524eea81cdded83c5b369a,
                    "styled" : tile_layer_12f682c267e8409eb3cf863f8aba91d6,
                    "US States" : tile_layer_a1486c62d70a4ff78379f36fc29debb7,
                },
            };
            L.control.layers(
                layer_control_58c2534d289141ad81460d22b9a88901.base_layers,
                layer_control_58c2534d289141ad81460d22b9a88901.overlays,
                {"autoZIndex": true, "collapsed": true, "position": "topright"}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
            tile_layer_402b4dec6b92451b9dcdee6d31e9695f.remove();
            tile_layer_2d40bee1a9454f8db0dfb853cb7848d1.remove();
            tile_layer_0fab0314b6524eea81cdded83c5b369a.remove();
        
    
            L.control.fullscreen(
                {"forceSeparateButton": false, "position": "topleft", "title": "Full Screen", "titleCancel": "Exit Full Screen"}
            ).addTo(map_60cd5cbebfbc446293ec6e680728c9a6);
        
    
                var lat_lng_popup_e64dfc1dc42b4bf094057a380a477ada = L.popup();
                function latLngPop(e) {
                    lat_lng_popup_e64dfc1dc42b4bf094057a380a477ada
                        .setLatLng(e.latlng)
                        .setContent("Latitude: " + e.latlng.lat.toFixed(4) +
                                    "<br>Longitude: " + e.latlng.lng.toFixed(4))
                        .openOn(map_60cd5cbebfbc446293ec6e680728c9a6);
                    }
                map_60cd5cbebfbc446293ec6e680728c9a6.on('click', latLngPop);
            
</script>\" style=\"position:absolute;width:100%;height:100%;left:0;top:0;border:none !important;\" allowfullscreen webkitallowfullscreen mozallowfullscreen></iframe></div></div>"
],
"text/plain": [
"<geemap.eefolium.Map at 0x7fbf57f0b160>"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# Add layer control to the map.\n",
"Map.setControlVisibility()\n",
"# Display the map.\n",
"Map"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [],
"source": [
"Map.publish(name='gee_folium_map', headline='Terrain Visualization', visibility='PUBLIC', overwrite=True)"
]
}
],
"metadata": {
"hide_input": false,
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.8.2"
},
"toc": {
"base_numbering": 1,
"nav_menu": {},
"number_sections": true,
"sideBar": true,
"skip_h1_title": true,
"title_cell": "Table of Contents",
"title_sidebar": "Table of Contents",
"toc_cell": false,
"toc_position": {
"height": "calc(100% - 180px)",
"left": "10px",
"top": "150px",
"width": "318px"
},
"toc_section_display": true,
"toc_window_display": true
},
"varInspector": {
"cols": {
"lenName": 16,
"lenType": 16,
"lenVar": 40
},
"kernels_config": {
"python": {
"delete_cmd_postfix": "",
"delete_cmd_prefix": "del ",
"library": "var_list.py",
"varRefreshCmd": "print(var_dic_list())"
},
"r": {
"delete_cmd_postfix": ") ",
"delete_cmd_prefix": "rm(",
"library": "var_list.r",
"varRefreshCmd": "cat(var_dic_list()) "
}
},
"types_to_exclude": [
"module",
"function",
"builtin_function_or_method",
"instance",
"_Feature"
],
"window_display": false
}
},
"nbformat": 4,
"nbformat_minor": 4
}
Loading

0 comments on commit 086230e

Please sign in to comment.