How to Connect Google Earth Engine with R Shiny
data:image/s3,"s3://crabby-images/e43f9/e43f9fe24f609c1e977d9f119b92c4cf9a671ca2" alt=""
Visualizing spatial data is always more challenging than it seems at first. There are too many moving parts, and the whole thing can quickly slow down your dashboard. Today you'll learn how to connect Google Earth Engine with R Shiny. We'll start by signing up for a free GEE account and configuring everything on the R end.
Want to integrate plain Google Maps in R Shiny dashboards? Our detailed google maps guide has you covered.Table of contents:
- How to Setup Google Earth Engine with R
- How to Render a Google Earth Map with R
- Connect Google Earth Engine with R Shiny - Start Here
- Summary of R Shiny + Google Earth Engine
How to Setup Google Earth Engine with R
Before you can connect Google Earth Engine with R Shiny, you'll have to register for a GEE account. It's completely free, but the registration page states it could take some time for your account to get approved. In our experience registration was a breeze, as we got a confirmation mail seconds after submitting:data:image/s3,"s3://crabby-images/29601/296016c3061143d6e9e1cb1faad0fbe69140567c" alt="Image 1 - Google Earth Engine registration mail"
rgee
R package. Now, R isn't officially supported by the Google Earth Engine (only JavaScript and Python), so this package serves as a bridge. It allows you to write R code that essentially boils down to Python behind the scenes.
But how can R call Python code? We have a complete guide on using R and Python together.Use the following command to install the
rgee
package:
install.packages("rgee")The setup isn't done yet. You'll have to load the package and call the
ee_install()
function. It will create a Python virtual environment and install all Python dependencies for you. It goes without saying, but you should have Python 3 installed before running the code snippet below:
library(rgee) rgee::ee_install()We're using Miniforge, a minimal distribution of Anaconda, and the above snippet worked without any issues. The final step in this setup section is to call the
ee_Initialize()
function. It will do all the heavy lifting for you - initialize the previously created Python virtual environment and install all the required libraries:
library(rgee)
ee_Initialize()
Here's what you should see in RStudio:
data:image/s3,"s3://crabby-images/cca98/cca98bc94eac63c048285bc6a424de9193e4a5ea" alt="Image 2 - Initializing Python virtual environment for rgee"
data:image/s3,"s3://crabby-images/b24cf/b24cf8ee0e01f582f9686fa83c96447a3e460171" alt="Image 3 - Authenticating Google account for Python libraries"
data:image/s3,"s3://crabby-images/7b78c/7b78c5a6e500f7e641104038e22b866afd8cdb7f" alt="Image 4 - Google account authentication code"
data:image/s3,"s3://crabby-images/7f74e/7f74e17434b5f889476ed5f66ac44907b3364909" alt="Image 5 - Pasting Google account authentication code in R console"
data:image/s3,"s3://crabby-images/e8279/e8279aac7b68daab1f495c5a47940c06b8da0edf" alt="Image 6 - Google Earth Engine local root directory"
How to Render a Google Earth Map with R
The hard part is now over and we're ready to have some fun with Google Earth Engine in R. The example you'll see is quite basic, and can be found on the official package GitHub page. It's sort of a Hello World of Google Earth Engine program in R but will be enough to understand the fundamentals. First, we'll write a functioncreateTimeBand
that adds a band containing image data as years since 1991. Then, we map the time band creation helper over the night-time lights collection image dataset.
Finally, we will compute a linear fit over the series of values at each pixel, visualizing the y-intercept in green, and positive/negative slopes in red/blue:
library(rgee) createTimeBand <- function(img) { year <- ee$Date(img$get("system:time_start"))$get("year")$subtract(1991L) ee$Image(year)$byte()$addBands(img) } collection <- ee$ ImageCollection("NOAA/DMSP-OLS/NIGHTTIME_LIGHTS")$ select("stable_lights")$ map(createTimeBand) col_reduce <- collection$reduce(ee$Reducer$linearFit()) col_reduce <- col_reduce$addBands( col_reduce$select("scale") ) ee_print(col_reduce)
data:image/s3,"s3://crabby-images/8b4b6/8b4b633b5ff2eb8dc7d6c1c9d5378810900003f6" alt="Image 7 - Google Earth Engine program output"
col_reduce
layer:
Map$setCenter(9.08203, 47.39835, 3) Map$addLayer( eeObject = col_reduce, visParams = list( bands = c("scale", "offset", "scale"), min = 0, max = c(0.18, 20, -0.18) ), name = "stable lights trend" )Here's what the finished map looks like:
data:image/s3,"s3://crabby-images/83e4c/83e4c473e9f6dace21f9da6bec2eed0dcbb4d478" alt="Image 8 - Google Earth Engine map in R"
Connect Google Earth Engine with R Shiny - Start Here
R Shiny is our favorite R package for creating interactive dashboards, so naturally, we want to see if it's possible to connect R Shiny with Google Earth Engine. Spoiler alert: It is, and the syntax will be near-identical to what we covered in the previous section. There's norenderGoogleEarthEngine
function available, unfortunately, so we'll have to use the Leaflet package to render the map.
Our dashboard will have two panels:
sidebarPanel
- Contains the configurable values for latitude and longitude that update the map on the button click.mainPanel
- Contains the Google Earth Engine map rendered by Leaflet.
library(rgee) library(leaflet) library(shiny) createTimeBand <- function(img) { year <- ee$Date(img$get("system:time_start"))$get("year")$subtract(1991L) ee$Image(year)$byte()$addBands(img) } collection <- ee$ ImageCollection("NOAA/DMSP-OLS/NIGHTTIME_LIGHTS")$ select("stable_lights")$ map(createTimeBand) col_reduce <- collection$reduce(ee$Reducer$linearFit()) col_reduce <- col_reduce$addBands( col_reduce$select("scale") ) ui <- fluidPage( sidebarLayout( sidebarPanel( numericInput(inputId = "in_latitude", label = "Latitude", value = 9.08203, min = -90, max = 90, step = 0.1), numericInput(inputId = "in_longitude", label = "Longitude", value = 47.39835, min = -180, max = 180, step = 0.1), actionButton(inputId = "reposition", label = "Reposition Map") ), mainPanel( leafletOutput(outputId = "map") ) ) ) server <- function(input, output) { map <- eventReactive(input$reposition, { Map$setCenter(input$in_latitude, input$in_longitude, 3) Map$addLayer( eeObject = col_reduce, visParams = list( bands = c("scale", "offset", "scale"), min = 0, max = c(0.18, 20, -0.18) ), name = "stable lights trend" ) }, ignoreNULL = FALSE ) output$map <- renderLeaflet({ map() }) } shinyApp(ui = ui, server = server)
data:image/s3,"s3://crabby-images/1380d/1380d472cc78fed52b4b217f45e9c06780f3f458" alt="Image 9 - R Shiny dashboard rendering the Google Earth Engine map"
Summary of R Shiny + Google Earth Engine
Today you've learned how to connect Google Earth Engine with R Shiny. There are a lot of setups involved, but we hope it wasn't too tedious to follow. You can certainly use Google Earth Engine in your Shiny dashboards to overlay interesting layers around the base map. We went over a simple example, but encourage you to experiment further on your own. Share your results with us on Twitter - @appsilon. We'd love to see what you come up with.Want to dive deeper into Leaflet? Our detailed guide is all you need to make stunning geomaps.