{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "\n", " \n", " \n", " \n", "
View source on GitHubNotebook Viewer Run in Google Colab
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Install Earth Engine API and geemap\n", "Install the [Earth Engine Python API](https://developers.google.com/earth-engine/python_install) and [geemap](https://geemap.org). The **geemap** Python package is built upon the [ipyleaflet](https://github.com/jupyter-widgets/ipyleaflet) and [folium](https://github.com/python-visualization/folium) packages and implements several methods for interacting with Earth Engine data layers, such as `Map.addLayer()`, `Map.setCenter()`, and `Map.centerObject()`.\n", "The following script checks if the geemap package has been installed. If not, it will install geemap, which automatically installs its [dependencies](https://github.com/giswqs/geemap#dependencies), including earthengine-api, folium, and ipyleaflet." ] }, { "cell_type": "code", "metadata": {}, "source": [ "# Installs geemap package\n", "import subprocess\n", "\n", "try:\n", " import geemap\n", "except ImportError:\n", " print('Installing geemap ...')\n", " subprocess.check_call([\"python\", '-m', 'pip', 'install', 'geemap'])" ], "outputs": [], "execution_count": null }, { "cell_type": "code", "metadata": {}, "source": [ "import ee\n", "import geemap" ], "outputs": [], "execution_count": null }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Create an interactive map \n", "The default basemap is `Google Maps`. [Additional basemaps](https://github.com/giswqs/geemap/blob/master/geemap/basemaps.py) can be added using the `Map.add_basemap()` function. " ] }, { "cell_type": "code", "metadata": {}, "source": [ "Map = geemap.Map(center=[40,-100], zoom=4)\n", "Map" ], "outputs": [], "execution_count": null }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Add Earth Engine Python script " ] }, { "cell_type": "code", "metadata": {}, "source": [ "# Add Earth Engine dataset\n", "fc = ee.FeatureCollection('TIGER/2018/States').filter(ee.Filter.eq('STUSPS', 'MN'))\n", "# Filter the L7 collection to a single month.\n", "collection = (ee.ImageCollection('LE7_L1T_TOA')\n", " .filterDate(\"2002-11-01\", \"2002-12-01\")\n", " .filterBounds(fc))\n", "\n", "def NDVI(image):\n", " \"\"\"A function to compute NDVI.\"\"\"\n", " return image.expression('float(b(\"B4\") - b(\"B3\")) / (b(\"B4\") + b(\"B3\"))')\n", "\n", "\n", "def SAVI(image):\n", " \"\"\"A function to compute Soil Adjusted Vegetation Index.\"\"\"\n", " return ee.Image(0).expression(\n", " '(1 + L) * float(nir - red)/ (nir + red + L)',\n", " {\n", " 'nir': image.select('B4'),\n", " 'red': image.select('B3'),\n", " 'L': 0.2\n", " })\n", "\n", "vis = {\n", " 'min': 0,\n", " 'max': 1,\n", " 'palette': [\n", " 'FFFFFF', 'CE7E45', 'DF923D', 'F1B555', 'FCD163',\n", " '99B718', '74A901', '66A000', '529400', '3E8601',\n", " '207401', '056201', '004C00', '023B01', '012E01',\n", " '011D01', '011301'\n", " ]}\n", "\n", "Map.setCenter(-110, 40, 5)\n", "Map.addLayer(collection.map(NDVI).mean(), vis)\n", "Map.addLayer(collection.map(SAVI).mean(), vis)\n", "\n" ], "outputs": [], "execution_count": null }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Display Earth Engine data layers " ] }, { "cell_type": "code", "metadata": {}, "source": [ "Map.addLayerControl() # This line is not needed for ipyleaflet-based Map.\n", "Map" ], "outputs": [], "execution_count": null } ], "metadata": { "anaconda-cloud": {}, "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.6.1" } }, "nbformat": 4, "nbformat_minor": 4 }