gpt4 book ai didi

r - 如何在 map (ggplot)上放置比例尺和指北针?

转载 作者:行者123 更新时间:2023-12-03 20:06:59 45 4
gpt4 key购买 nike

我正在尝试使用“ggsn”包放置比例尺和指北针。
但我收到一条错误消息:

错误:annotation_custom 仅适用于笛卡尔坐标

此外: 警告消息:

1:在 min(data$long) 中:没有非缺失的 min 参数;返回信息

2:在 max(data$long) 中:没有非缺失的 max 参数;返回 -Inf

3:在 min(data$lat) 中:没有非缺失的 min 参数;返回信息

4:在 max(data$lat) 中:没有非缺失的 max 参数;返回 -Inf

5:删除了 1374840 行包含非有限值 (stat_contour)。

我的代码是这样的:

#loading the map
world <- maps::map("world2", fill=TRUE, plot=FALSE) # world2 is the Pacific centered map with longitude [0,360]

IDs <- sapply(strsplit(world$names, ":"), function(x) x[1])
world <- map2SpatialPolygons(world, IDs=IDs, proj4string=CRS("+proj=longlat +datum=WGS84 +no_defs +ellps=WGS84 +towgs84=0,0,0"))

world_map <- fortify(world)

#load the bathymetry
bat <- marmap::getNOAA.bathy(lon1 = -5.0000, lon2 = -80.0000, lat1 = 14, lat2 = -70.61, keep=T)

#converting the bathymetry in data.frame
bat2 = marmap::fortify.bathy(bat)

g <- ggplot(AR, aes(x = lon, y = lat)) + #(old: Longitude #Latitude)
geom_path(aes(group = sex, col = sex), size = 0.8, alpha = 0.5) +
geom_map(data = world_map, map=world_map, aes(x = long, y = lat, map_id = id), fill = "darkgray") +
geom_contour(data = bat2,
aes(x=x, y=y, z=z),
breaks=c(-200),
size=c(0.3),
colour="blue")+
xlim(extendrange(AR$lon, f = 0.1)) + #(old: Longitude)
ylim(extendrange(AR$lat, f = 0.1)) + #(old: Latitude)
coord_map("ortho", orientation = c(-40, -40, 0))

g +
ggsn::scalebar(world_map, dist = 100,location = "bottomright", transform = TRUE, #Adicione uma barra de escala
dist_unit = "km", st.dist = 0.03, st.size = 2, model = 'WGS84') +
ggsn::north(world_map, scale = .1)

我的部分数据:
structure(list(lon = c(-38.8745, -38.8676, -38.9445, -38.9811, 
-38.9322, -38.9386), lat = c(-14.09437, -14.25664, -14.34518,
-14.51857, -14.95994, -15.41684), bmode = c(1.396, 1.375, 1.346,
1.248, 1.074, 1.289), bmode.5 = c(1, 1, 1, 1, 1, 1), ID = structure(c(53L,
53L, 53L, 53L, 53L, 53L), .Label = c("10946.05", "20162.03",
"21792.03", "21800.03", "21810.03", "24640.03", "24641.05", "24642.03",
"27258.05", "27259.03", "27261.03", "27261.05", "27261.07", "33000.05",
"37231.07", "37234.05", "37288.07", "42521.07", "50682.07", "50687.07",
"60004.07", "81122.09", "81123.09", "81124.09", "81125.09", "81126.09",
"84497.1", "87632.12", "87759.08", "87761.08", "87762.08", "87763.08",
"87764.08", "87765.08", "87766.08", "87768.08", "87768.11", "87769.11",
"87770.08", "87773.08", "87773.1", "87773.11", "87774.09", "87774.11",
"87775.08", "87776.08", "87776.11", "87777.1", "87778.08", "87783.09",
"88724.1", "88727.09", "111868.11", "111871.12", "112702.12",
"112712.12", "112714.12", "120947.12", "121189.12", "121192.12",
"121196.12", "1211931.12"), class = "factor"), sex = structure(c(3L,
3L, 3L, 3L, 3L, 3L), .Label = c("F", "Fc", "M"), class = "factor"),
speed = c(0.921691675, 2.990097297, 2.137609076, 3.259383146,
8.173674567, 8.413534172), area = structure(c(3L, 3L, 3L,
3L, 3L, 3L), .Label = c("AA", "AM", "AR"), class = "factor"),
angulo = c(41.027, -43.41, 29.056, 18.241, -7.125, -4.702
), angle_rel = c(0.7160619, -0.7576522, 0.5071251, 0.3183724,
-0.1243479, -0.08206201), bat.depth = c(-45L, -397L, -32L,
-29L, -21L, -3L), dist = c(5.53015005, 17.94058378, 12.82565446,
19.55629887, 49.0420474, 50.48120503), angulo_modulo = c(41.027,
43.41, 29.056, 18.241, 7.125, 4.702), curva = structure(c(1L,
1L, 1L, 1L, 1L, 1L), .Label = c("curva", "reta"), class = "factor")), row.names = 2:7, class = "data.frame")

我怎么解决这个问题?

####EDIT 1

我已经编辑了我的帖子,现在对象“world_map”可用。

我在使用 ggspatial 时遇到问题。
我加载了您提到的所有包并运行了命令,但无法执行该功能。
我去添加包“ggspatial”,但出现以下消息:
"* installing * source * package 'ggspatial' ...
** package 'ggspatial' successfully unpacked and MD5 sums checked
** R
** inst
** byte-compile and prepare package for lazy loading
Error: .onLoad failed in loadNamespace () for 'sf', details:
  call: get (genname, envir = envir)
  error: object 'group_split' not found
ERROR: lazy loading failed for package 'ggspatial'
* removing 'C: /Users/annel/OneDrive/Documentos/R/win-library/3.5/ggspatial'
In R CMD INSTALL
Warning in install.packages:
  installation of package ‘ggspatial’ had non-zero exit status

The downloaded source packages are in
‘C: \ Users \ annel \ AppData \ Local \ Temp \ RtmpKueyQV \ downloaded_packages’ "

当我执行您请求的命令时,我收到消息:
Error in loadNamespace (name): there is no package called ‘ggspatial’

最佳答案

我不知道 ggsn包,但如果您不介意使用 ggspatial包,这是我理解你想要实现的一个例子。由于我无法重现您的代码,因此我已经包含了我自己的自定义数据集和测深数据......并使用了一些漂亮的字体来获得更好看的最终 map !

# Load necessary packages
library(tidyverse)
library(ggrepel)
library(sf)
library(marmap)

# Create random data
fake_data <- tibble(
Latitude = c(45.36, 46.74, 45.35, 45.28, 45.21, 45.92, 43.83, 46.80, 43.70, 43.97),
Year = factor(c(2010, 2010, 2010, 2010, 2010, 2007, 2008, 2008, 2008, 2008)),
Longitude = c(-2.64, -3.33, -3.22, -2.77, -2.54, -2.69, -1.99, -2.71, -1.68, -2.16),
Lab = c("960", "950", "956", "962", "961", "768", "865", "848", "866", "860")
)

# Transform data points into geographic objects
Sites_geo <- fake_data %>%
st_as_sf(coords = c("Longitude", "Latitude"), crs = 4326)

# Get bathymetry data
bathy <- getNOAA.bathy(-8, 0, 42, 50, res = 1, keep = TRUE)
ggbathy <- fortify(bathy)

# Get countries outline
pays <- rnaturalearth::ne_countries(
country = c("France", "Spain"),
scale = "large", returnclass = "sf"
)

# Base plot
pl <- ggplot(data = pays) +
geom_contour(
data = ggbathy, aes(x = x, y = y, z = z),
binwidth = 200, color = "grey80", size = 0.3
) +
geom_contour(
data = ggbathy, aes(x = x, y = y, z = z),
binwidth = 1000, color = "grey60", size = 0.4
) +
geom_sf() +
geom_sf(data = Sites_geo, aes(fill = Year), shape = 21) +
geom_text_repel(
data = fake_data, aes(x = Longitude, y = Latitude, label = Lab),
force = 3, family = "ArcherPro Book"
) +
coord_sf(xlim = c(-6, 0), ylim = c(43, 48.5), expand = FALSE) +
scale_fill_viridis_d() +
labs(x = "", y = "", fill = "Year") +
theme_bw(base_family = "ArcherPro Book")

# Add scale and North arrow
pl +
ggspatial::annotation_scale(
location = "tr",
bar_cols = c("grey60", "white"),
text_family = "ArcherPro Book"
) +
ggspatial::annotation_north_arrow(
location = "tr", which_north = "true",
pad_x = unit(0.4, "in"), pad_y = unit(0.4, "in"),
style = ggspatial::north_arrow_nautical(
fill = c("grey40", "white"),
line_col = "grey20",
text_family = "ArcherPro Book"
)
)

enter image description here

关于r - 如何在 map (ggplot)上放置比例尺和指北针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61809382/

45 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com