inst/examples/leafletsync/sync_offset_continuous.R

library(shiny)
library(leaflet)
library(sf)
library(leaflet.extras2)
df <- st_as_sf(breweries91)

ui <- fluidPage(
  h4("1 Continuous Map built by 4 different Maps"),
  tags$head(tags$style(".shiny-split-layout {margin-bottom: 4px;}")),
  splitLayout(cellWidths = rep("50%",2),
              leafletOutput("map1", height = 400),
              leafletOutput("map2", height = 400),
  ),
  splitLayout(cellWidths = rep("50%",2),
              leafletOutput("map3", height = 400),
              leafletOutput("map4", height = 400)
  ),
  actionButton("sync", label = "Sync all maps"),
  actionButton("unsync", label = "Unsync all maps")
)

server <- function(input, output, session) {
  output$map1 <- renderLeaflet({
    leaflet() %>%
      addTiles() %>%
      addCircleMarkers(data = df, color = "red") %>%
      setView(lng = 10.55, lat = 49.76, zoom = 10)
  })
  output$map2 <- renderLeaflet({
    leaflet() %>%
      addTiles() %>%
      addCircleMarkers(data = df, color = "orange")
  })
  output$map3 <- renderLeaflet({
    leaflet() %>%
      addTiles() %>%
      addCircleMarkers(data = df, color = "purple")
  })
  output$map4 <- renderLeaflet({
    leaflet() %>%
      addTiles() %>%
      addCircleMarkers(data = df, color = "blue")
  })
  observe({
    leafletProxy("map1") %>%
      addLeafletsync(ids = c("map1","map2","map3","map4"),
                     options = list(
                       "map1" = leafletsyncOptions(
                         syncCursor = FALSE,noInitialSync = FALSE,
                         offsetFn = JS("function (center, zoom, refMap, tgtMap) {
                                          var refC = refMap.getContainer();
                                          var tgtC = tgtMap.getContainer();
                                          var pt = refMap.project(center, zoom)
                                                         .subtract([refC.offsetLeft, refC.offsetTop])
                                                         .subtract(refMap.getSize().divideBy(2))
                                                         .add([tgtC.offsetLeft, tgtC.offsetTop])
                                                         .add(tgtMap.getSize().divideBy(2));
                                          return refMap.unproject(pt, zoom);
                                      }")),
                       "map2" = leafletsyncOptions(
                         syncCursor = FALSE,noInitialSync = FALSE,
                         offsetFn = JS("function (center, zoom, refMap, tgtMap) {
                                          var refC = refMap.getContainer();
                                          var tgtC = tgtMap.getContainer();
                                          var pt = refMap.project(center, zoom)
                                                         .subtract([refC.offsetLeft, refC.offsetTop])
                                                         .subtract(refMap.getSize().divideBy(2))
                                                         .add([tgtC.offsetLeft, tgtC.offsetTop])
                                                         .add(tgtMap.getSize().divideBy(2));
                                          return refMap.unproject(pt, zoom);
                                      }")),
                       "map3" = leafletsyncOptions(
                         syncCursor = FALSE,noInitialSync = FALSE,
                         offsetFn = JS("function (center, zoom, refMap, tgtMap) {
                                          var refC = refMap.getContainer();
                                          var tgtC = tgtMap.getContainer();
                                          var pt = refMap.project(center, zoom)
                                                         .subtract([refC.offsetLeft, refC.offsetTop])
                                                         .subtract(refMap.getSize().divideBy(2))
                                                         .add([tgtC.offsetLeft, tgtC.offsetTop])
                                                         .add(tgtMap.getSize().divideBy(2));
                                          return refMap.unproject(pt, zoom);
                                      }")),
                       "map4" = leafletsyncOptions(
                         syncCursor = FALSE, noInitialSync = FALSE,
                         offsetFn = JS("function (center, zoom, refMap, tgtMap) {
                                          var refC = refMap.getContainer();
                                          var tgtC = tgtMap.getContainer();
                                          var pt = refMap.project(center, zoom)
                                                         .subtract([refC.offsetLeft, refC.offsetTop])
                                                         .subtract(refMap.getSize().divideBy(2))
                                                         .add([tgtC.offsetLeft, tgtC.offsetTop])
                                                         .add(tgtMap.getSize().divideBy(2));
                                          return refMap.unproject(pt, zoom);
                                      }"))
                     ))
  })

  observeEvent(input$sync, {
    leafletProxy("map1") %>%
      addLeafletsync(c("map1","map2","map3","map4"))
  })
  observeEvent(input$unsync, {
    leafletProxy("map1") %>%
      unsync(id = "map1", unsyncids = c("map2","map3","map4")) %>%
      unsync(id = "map2", unsyncids = c("map1","map3","map4")) %>%
      unsync(id = "map3", unsyncids = c("map1","map2","map4")) %>%
      unsync(id = "map4", unsyncids = c("map1","map2","map3"))
  })
}
shinyApp(ui, server)

Try the leaflet.extras2 package in your browser

Any scripts or data that you put into this service are public.

leaflet.extras2 documentation built on Aug. 21, 2023, 5:08 p.m.