传单 (R) addPopups:coordinates/properties

Leaflet (R) addPopups: coordinates/properties

一般而言,我对处理空间数据和传单还很陌生。我在为我的地图创建弹出窗口时遇到困难。基本上我在弹出窗口中想要的是多边形的坐标和属性之一(class 的类型)。下面是我的 geoJSON 文件的测试示例:

{
  "type": "FeatureCollection",
  "features": [
    {
      "type": "Feature",
      "properties": {"class": "blah"},
      "geometry": {
        "type": "Polygon",
        "coordinates": [
          [
            [
              -81.7987060546875,
              32.74570253945518
            ],
            [
              -81.6229248046875,
              32.16631295696736
            ],
            [
              -80.958251953125,
              32.4263401615464
            ],
            [
              -81.2713623046875,
              32.791892438123696
            ],
            [
              -81.7437744140625,
              32.97180377635759
            ],
            [
              -81.7987060546875,
              32.74570253945518
            ]
          ]
        ]
      }
    },
    {
      "type": "Feature",
      "properties": {"class": "blah2"},
      "geometry": {
        "type": "Polygon",
        "coordinates": [
          [
            [
              -82.056884765625,
              33.55512901742288
            ],
            [
              -81.4471435546875,
              33.247875947924385
            ],
            [
              -81.40869140625,
              33.80653802509606
            ],
            [
              -82.078857421875,
              33.88865750124075
            ],
            [
              -82.40295410156249,
              33.58716733904656
            ],
            [
              -82.056884765625,
              33.55512901742288
            ]
          ]
        ]
      }
    },
    {
      "type": "Feature",
      "properties": {"class": "blahh3"},
      "geometry": {
        "type": "Polygon",
        "coordinates": [
          [
            [
              -83.485107421875,
              32.930318199070534
            ],
            [
              -83.07861328125,
              31.863562548378965
            ],
            [
              -82.21618652343749,
              32.11049589629439
            ],
            [
              -82.97973632812499,
              33.22030778968541
            ],
            [
              -83.726806640625,
              33.211116472416855
            ],
            [
              -83.485107421875,
              32.930318199070534
            ]
          ]
        ]
      }
    }
  ]
}

这是我目前创建地图的代码,但我 struggling/don 甚至不知道从哪里开始创建包含我的坐标和 属性 的弹出窗口:

blahTest <- geojson_read("/file/path/...", what = "sp")
fpal <- colorFactor("viridis", blahTest$class)
leaflet(blahTest) %>%
  addTiles() %>%
  addPolygons(stroke = FALSE, smoothFactor = 0.3, fillOpacity = 1,
              color = ~fpal(class)) %>%
  addLegend(colors = ~fpal, opacity = 1.0, labels = ~fpal) %>%
  addPopups()

提前致谢!

概览

根据@patL 的建议,我在 leaflet::addPolygon() 函数中使用了 popup 参数来添加标签 classcoordinates 来定义 [=15] 中的每个多边形=].

我将您的示例数据保存为 .gejson 文件并使用 sf::read_sf() and produced the HTML table within the popup using the htmlTable package after reading How to add an html table to leaflet popup 导入它。

# load necessary package
library( htmlTable )
library( leaflet )
library( sf )

# load necessary data 
blahTest <- 
  read_sf(
    dsn = "test.geojson"
    , layer = "OGRGeoJSON"
  )

# map data values to colors
fpal <- colorFactor( palette = "viridis", domain = blahTest$class)

# create map
my.map <-
  leaflet( data = blahTest ) %>%
  addTiles() %>%
  addPolygons( stroke = FALSE
               , smoothFactor = 0.3
               , fillOpacity = 1
               , color = ~fpal( class )
               , popup = paste0(
                 "<b>Class: </b>"
                 , blahTest$class
                 , "<br>"
                 , "<b>Coordinates: </b>"
                 , "<br>"
                 , lapply( 
                     X = blahTest$geometry
                     , FUN = function( i ) 
                       htmlTable( 
                         x = i[[1]]
                         , header = c( "Longitude", "Latitude" )
                       )
                     )
                   ) ) %>%
  addLegend( pal = fpal
             , values = ~class
             , labels = ~class
             , title = "Legend"
             , position = "topright"
             , opacity = 1.0 )
# view map
my.map

# end of script #