【问题标题】:Dynamic plotting using ggmap package in R在 R 中使用 ggmap 包进行动态绘图
【发布时间】:2015-08-23 19:08:28
【问题描述】:

我正在尝试在谷歌地图上绘制我的观点。但是,我面临的问题是我必须为每个输入数据文件设置位置点和缩放。我试图通过变量使用它,但它不起作用。有人可以帮忙吗?

这是我尝试过的:

library(ggmap)
library(ggplot2)
lionmap <- get_map(location=c(70.76, 21.038), zoom=12, maptype="hybrid")

此代码仅适用于静态点。如何让它动态化?

这是我的数据集的头部结构:

  lion.id       date     time activity      lat     long  distance
1       2 05-05-2002 10:45:00  Feeding 21.14169 70.79053   0.00000
2       2 05-06-2002 10:00:00  Resting 21.14158 70.79314 271.50019
3       2 05-06-2002 19:22:00  Walking 21.14158 70.79314   0.00000
4       2 05-06-2002 19:25:00  Walking 21.14164 70.79267  49.43485
5       2 05-06-2002 19:30:00  Resting 21.14181 70.79222  49.71674
6       2 05-06-2002 23:15:00  Walking 21.14181 70.79222   0.00000

structure(list(lion.id = c(2L, 2L, 2L, 2L, 2L, 2L), date = c("05-05-2002", 
"05-06-2002", "05-06-2002", "05-06-2002", "05-06-2002", "05-06-2002"
), time = c("10:45:00", "10:00:00", "19:22:00", "19:25:00", "19:30:00", 
"23:15:00"), activity = c("Feeding", "Resting", "Walking", "Walking", 
"Resting", "Walking"), lat = c(21.1416944444444, 21.1415833333333, 
21.1415833333333, 21.1416388888889, 21.1418055555556, 21.1418055555556
), long = c(70.7905277777778, 70.7931388888889, 70.7931388888889, 
70.7926666666667, 70.7922222222222, 70.7922222222222), distance = c(0, 
271.500188739303, 0, 49.4348465237462, 49.7167383971771, 0)), .Names = c("lion.id", 
"date", "time", "activity", "lat", "long", "distance"), row.names = c(NA, 
-6L), class = "data.frame")

【问题讨论】:

  • 请问您所说的“我必须为每个输入数据文件设置位置点和缩放”是什么意思?你有多个数据框吗?
  • 如果您的意思是要绘制所有数据点,您可以执行lionmap &lt;- get_map(location = c(70.79, 21.14), zoom = 15, maptype = "hybrid"); ggmap(lionmap) + geom_point(data = mydf, aes(x = lon, y = lat), size = 3, color = "white") 之类的操作。既然您说要使地图动态化,我想知道您是否更愿意使用交互式地图。
  • 我发现leaflet 对在 R 中绘制交互式地图很有用。如果这就是您所追求的,您可以考虑使用它而不是 ggmap

标签: r ggmap


【解决方案1】:

我不确定您想要什么,但我想为您提供两种选择。如果要创建静态地图,可以使用ggmap。

library(ggplot2)
library(ggmap)

lionmap <- get_map(location = c(70.79, 21.14), zoom = 15, maptype = "hybrid")

ggmap(lionmap) + geom_point(data = mydf, aes(x = long, y = lat), size = 3, color = "white")

如果你真的想要一个交互式地图,你可以使用传单,例如。

library(leaflet)
library(magrittr)

leaflet(mydf) %>%
addTiles() %>%
setView(lng = 70.79, lat = 21.14, zoom = 15) %>%
addCircleMarkers()

数据

mydf <- structure(list(lion.id = c(2L, 2L, 2L, 2L, 2L, 2L), date = c("05-05-2002", 
"05-06-2002", "05-06-2002", "05-06-2002", "05-06-2002", "05-06-2002"
), time = c("10:45:00", "10:00:00", "19:22:00", "19:25:00", "19:30:00", 
"23:15:00"), activity = c("Feeding", "Resting", "Walking", "Walking", 
"Resting", "Walking"), lat = c(21.1416944444444, 21.1415833333333, 
21.1415833333333, 21.1416388888889, 21.1418055555556, 21.1418055555556
), long = c(70.7905277777778, 70.7931388888889, 70.7931388888889, 
70.7926666666667, 70.7922222222222, 70.7922222222222), distance = c(0, 
271.500188739303, 0, 49.4348465237462, 49.7167383971771, 0)), .Names = c("lion.id", 
"date", "time", "activity", "lat", "long", "distance"), row.names = c(NA, 
-6L), class = "data.frame")

【讨论】:

  • 我可以在这一步中使用变量而不是静态纬度/经度点吗? setView(lng = 70.79, lat = 21.14, zoom = 15)
  • @ayush 你说的变量是什么意思?你指的是什么变量? setView() 确定地图的中心点。所以你确实需要经纬度。
猜你喜欢
  • 1970-01-01
  • 2019-11-18
  • 1970-01-01
  • 1970-01-01
  • 2018-08-31
  • 1970-01-01
  • 1970-01-01
  • 2011-11-06
  • 1970-01-01
相关资源
最近更新 更多