A comparison between geeViz and geeMap’s map visualization capabilities#

  • Both packages provide methods to visualize and summarize EE objects as well as non-EE-based image services

  • geeViz uses the localhost in a web server. It will run in notbooks, iPython, or a regular script

  • geeMap uses iPython widgets, and therefore needs to run from a notebook or iPython

  • geeViz uses geeMap when appropriate, but still relies on its own map visualization tool for a variety of reasons

  • This is intended to illustrate the basic map functionality of each package. Refer to each packages examples for more in-depth demos

github github

import ee

# Enter your project ID
projectID = 'lcms-292214'

ee.Initialize(project=projectID)


import geemap as gm
import geeViz.geeView as gv


gvMap = gv.Map
gmMap = gm.Map()

First, we’ll take a look at the two different map interfaces#

# geeMap you simply call the object
gmMap
# geeViz you use the view method
gvMap.view()
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m74S8bHeDCxomhfeR5hth7rF_fFGjzL0Gr4wW5UfHJKEkG0bB6bsU5xOGL1zBIyyLJUyuAZ-FCe2vykU-53SXClWXIHV9HtE5RzN_ubwgDJApZHUOgj8rITeXxz0cHUNv-HYkw3LeC6mqmnzeLPeTXdQA41Zs_8x3NcqGwaCgYKAYcSARESFQHGX2Mi-qafCu2_HWC9Eh4vUdlgzA0177&accessTokenCreationTime=1736449015119

Some methods are similar between the methods available#

  • addLayer

  • setCenter

  • centerObject

gmMap = gm.Map()

pt = ee.Geometry.Point([-111.92926447956665, 40.64356771453405])

gmMap.centerObject(pt,10)
gvMap.centerObject(pt,10)

gvMap.view()
gmMap
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m77QdujTP6bXeZFj8w7EqA8SNRRLSpw2CvY-ZvHQFa16Y-Evi1cFSjmBCgDYAouaot5waHrFbWoaczG2f9oSrAI3VQJuKaDgcSRvEV9FJja8ROxsuXQnx2ZlBjic--dL_LfKSDWLEWSfdUXvhWTCmBSWh42XJfKoyl1XXgaCgYKAaESARESFQHGX2MiTjPzzasi4khaRGS2dv1tSw0177&accessTokenCreationTime=1736449191862
gmMap = gm.Map()


gmMap.setCenter(-111.92926447956665, 40.64356771453405,10)
gvMap.setCenter(-111.92926447956665, 40.64356771453405,10)

gvMap.view()
gmMap
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m77UQqXXYY3C_GCo93dizymM-65pbh5tNevhlEiVpvVyxunFOR1I83gwH95QSNiiDfatcfCmOg4GP14ysZ6Y3r8jPt5MplCzcpxNPEYTemxCUVwQBT7csjJg3osFX9ZUMIuoyJejdY4NV0sMKr2356i-ezU4Q3WywjoVdAaCgYKAVYSARESFQHGX2Mibfb-QT95VTnwA9Raa4QXPA0177&accessTokenCreationTime=1736449230047
  • Adding layers is very similar

    • geeMap makes the top layer on the map the bottom layer in the layer UI list, while geeViz they appear in the same order as on the map (you can reorder most map layers in geeViz with a drag and drop to reorder)

gmMap = gm.Map()

# Add Earth Engine dataset
dem = ee.Image("USGS/SRTMGL1_003")
landcover = ee.Image("ESA/GLOBCOVER_L4_200901_200912_V2_3").select("landcover")
landsat7 = ee.Image("LANDSAT/LE7_TOA_5YEAR/1999_2003").select(
    ["B1", "B2", "B3", "B4", "B5", "B7"]
)
states = ee.FeatureCollection("TIGER/2018/States")

# Set visualization parameters.
vis_params = {
    "min": 0,
    "max": 4000,
    "palette": ["006633", "E5FFCC", "662A00", "D8D8D8", "F5F5F5"],
}

# Add Earth Engine layers to Map
gmMap.addLayer(dem, vis_params, "SRTM DEM", True)
gmMap.addLayer(landcover, {}, "Land cover")
gmMap.addLayer(
    landsat7,
    {"bands": ["B4", "B3", "B2"], "min": 20, "max": 200, "gamma": 2.0},
    "Landsat 7",
)
gmMap.addLayer(states, {}, "US States")


gvMap.clearMap()


gvMap.addLayer(dem, vis_params, "SRTM DEM", True)
gvMap.addLayer(landcover, {}, "Land cover")
gvMap.addLayer(
    landsat7,
    {"bands": ["B4", "B3", "B2"], "min": 20, "max": 200, "gamma": 2.0},
    "Landsat 7",
)
gvMap.addLayer(states, {}, "US States")

gmMap.setCenter(-111.92926447956665, 40.64356771453405,10)
gvMap.setCenter(-111.92926447956665, 40.64356771453405,10)

gvMap.view()
gmMap
Adding layer: SRTM DEM
Adding layer: Land cover
Adding layer: Landsat 7
Adding layer: US States
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m75yAaGdm6U7MCoKKR9BCmGvJvBK2P9kysDQBeTeJd7vvizka1qso5ZaKrVniUXKCJnZzGmG0mb0ZHaeN7jemu5uCkXz1wgLJ8Ch5yeURDPW30BdNS410lX46B9cVhlEXLyFMZZFbEVb2-Erd--Ec19Zjw7KtF2adkjilQaCgYKAQASARESFQHGX2MinE2AkU7eSMmGg_wPB77l8g0177&accessTokenCreationTime=1736449244138
  • geeMap and geeViz provide different methods creating legends

  • geeViz will try to populate a legend with any single-band image or imageCollection its given

  • If an image or imageCollection has images with _class_name, _class_value, _class_palette properties, you can use "autoViz":True to populate a legend

  • geeMap provides methods to create legends

gmMap = gm.Map()
gvMap.clearMap()

legend_dict = {
    "11 Open Water": "466b9f",
    "12 Perennial Ice/Snow": "d1def8",
    "21 Developed, Open Space": "dec5c5",
    "22 Developed, Low Intensity": "d99282",
    "23 Developed, Medium Intensity": "eb0000",
    "24 Developed High Intensity": "ab0000",
    "31 Barren Land (Rock/Sand/Clay)": "b3ac9f",
    "41 Deciduous Forest": "68ab5f",
    "42 Evergreen Forest": "1c5f2c",
    "43 Mixed Forest": "b5c58f",
    "51 Dwarf Scrub": "af963c",
    "52 Shrub/Scrub": "ccb879",
    "71 Grassland/Herbaceous": "dfdfc2",
    "72 Sedge/Herbaceous": "d1d182",
    "73 Lichens": "a3cc51",
    "74 Moss": "82ba9e",
    "81 Pasture/Hay": "dcd939",
    "82 Cultivated Crops": "ab6c28",
    "90 Woody Wetlands": "b8d9eb",
    "95 Emergent Herbaceous Wetlands": "6c9fb8",
}

landcover = ee.Image("USGS/NLCD/NLCD2016").select("landcover")
gmMap.addLayer(landcover, {}, "NLCD Land Cover")

gmMap.add_legend(legend_title="NLCD Land Cover", legend_dict=legend_dict)


gvMap.addLayer(landcover,{'classLegendDict':legend_dict}, "NLCD Land Cover")

gmMap.setCenter(-111.92926447956665, 40.64356771453405,10)
gvMap.setCenter(-111.92926447956665, 40.64356771453405,10)


gvMap.view()
gmMap
Adding layer: NLCD Land Cover
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m74uWoqhGbZeslu5Y5XyDMp77uEheZApTvzf0y5J6f9yfwvnvrQV6FAWMayAkMdEflipFyADcISqV0Cui2x54HANEp-vPkDRujHkPIniQQr4gT54XV9X_yR0yJIhx19ryLfaVXA_cYJUnjQKLQxsEqgxcZUxmNuITPgDwgaCgYKARgSARESFQHGX2Mi5l3DyrYjbMCA0R5Yx7ypbQ0177&accessTokenCreationTime=1736449379765
gmMap = gm.Map()
gvMap.clearMap()

ee_class_table = """

Value	Color	Description
0	1c0dff	Water
1	05450a	Evergreen needleleaf forest
2	086a10	Evergreen broadleaf forest
3	54a708	Deciduous needleleaf forest
4	78d203	Deciduous broadleaf forest
5	009900	Mixed forest
6	c6b044	Closed shrublands
7	dcd159	Open shrublands
8	dade48	Woody savannas
9	fbff13	Savannas
10	b6ff05	Grasslands
11	27ff87	Permanent wetlands
12	c24f44	Croplands
13	a5a5a5	Urban and built-up
14	ff6d4c	Cropland/natural vegetation mosaic
15	69fff8	Snow and ice
16	f9ffa4	Barren or sparsely vegetated
254	ffffff	Unclassified

"""

landcover = ee.Image("MODIS/051/MCD12Q1/2013_01_01").select("Land_Cover_Type_1")

proj = landcover.projection().getInfo()
gmMap.setCenter(6.746, 46.529, 2)
gmMap.addLayer(landcover, {}, "MODIS Land Cover")

legend_dict = gm.legend_from_ee(ee_class_table)
gmMap.add_legend(legend_title="MODIS Global Land Cover", legend_dict=legend_dict)

gvMap.setCenter(6.746, 46.529,2)
gvMap.addLayer(landcover, {'autoViz':True,'canAreaChart':True,'areaChartParams':{'crs':proj['crs'],'transform':proj['transform'],'minZoomSpecifiedScale':5}}, "MODIS Land Cover")

gvMap.turnOnAutoAreaCharting()
gvMap.view()
gmMap
Adding layer: MODIS Land Cover
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m75k6Z1iJbdDiGFZ-pnNC3RH8teSuLUI5jSdXugz3e9TYJZIhGP-5bp5z0vcbGTgIuo8JZx3y6jkJMOKAivxXlJxJSla_eSAhuni9hPHc6H-94Se2JaLpThm5675eJEeOwz6yzBTSDjzd_YMvUV_EEhvbx53oOLdGH3nXAaCgYKAYYSARESFQHGX2Mi8pBTln8Xzvy2j6tNo1L5IQ0177&accessTokenCreationTime=1736449409579

Using geeMap and geeViz together#

  • Currently, geeViz is integrating the broad functionality of geeMap where appropriate.

  • We feel that many of the conversion functions and data extraction functions work well in a regular Python script, as well as in notebooks in iPython, so we can use them in geeViz as they are

  • As such, geeViz is building dependencies on geeMap

shp = gv.os.path.join(gv.sys.path[0],"data/gadm41_CHE_shp/gadm41_CHE_0.shp")

ch = gm.shp_to_ee(shp)

gmMap = gm.Map()
gvMap.clearMap()

gvMap.addLayer(ch,{},'Switzerland')
gmMap.addLayer(ch,{},'Switzerland')

gmMap.centerObject(ch)
gvMap.centerObject(ch)
gvMap.view()
gmMap
Adding layer: Switzerland
Starting webmap
Using default refresh token for geeView
Local web server at: http://localhost:8001/geeView/ already serving.
cwd a:\GEE\gee_py_modules_package\geeViz\examples
geeView URL: http://localhost:8001/geeView/?projectID=lcms-292214&accessToken=ya29.a0ARW5m74tIXYoPn4hkMn-Oe6unOBgllJ7REBa1O9OXi3mKoLxmhAdF2lQ2ewhWQ0epHNilBUop-B2slA78-L4Jc2SmsEIOliOgvEgyBVMEddrU5LU0w1PFsKucia9kzCNHcezGJycFLs63YEser90p5G0GYO37ibKFWIT1RbHgQaCgYKAWESARESFQHGX2MiSMYB7SOLCiQuwQdaiDaPvg0177&accessTokenCreationTime=1736449487135