左边的两列代表地理结构的坐标XY,左边的两列代表“每个”地理单位的大小(直径南北和东西)
我想以图形方式表示一个散点图,在这里绘制所有坐标,并在每个点上绘制一个包含每个地理单位直径的椭圆。
我怎样才能使用ggplot2?
您可以下载数据here
答案 0 :(得分:4)
使用ggforce中的geom_ellipse()
:
library(ggplot2)
library(ggforce)
d <- data.frame(
x = c(10, 20),
y = c(10, 20),
ns = c(5, 8),
ew = c(4, 4)
)
ggplot(d, aes(x0 = x, y0 = y, a = ew/2, b = ns/2, angle = 0)) +
geom_ellipse() +
coord_fixed()
由reprex package创建于2019-06-01(v0.2.1)
答案 1 :(得分:3)
我没有向what Claus Wilke already posted above添加任何新代码。所有的功劳都归功于克劳斯。我只是用实际数据测试它,并显示OP如何发布数据,
需要加载包
# install.packages(c("tidyverse"), dependencies = TRUE)
library(tidyverse)
阅读数据,
tbl <- read.table(
text = "
X Y Diameter_N_S Diameter_E_W
-4275 1145 77 96
-4855 1330 30 25
-4850 1612 45 90
-4990 1410 15 15
-5055 1230 60 50
-5065 1503 43 45
-5135 1305 40 50
-5505 1190 55 70
-5705 1430 90 40
-5645 1535 52 60
", header = TRUE, stringsAsFactors = FALSE) %>% as_tibble()
显示数据,
tbl
#> # A tibble: 10 x 4
#> X Y Diameter_N_S Diameter_E_W
#> <int> <int> <int> <int>
#> 1 -4275 1145 77 96
#> 2 -4855 1330 30 25
#> 3 -4850 1612 45 90
#> 4 -4990 1410 15 15
#> 5 -5055 1230 60 50
#> 6 -5065 1503 43 45
#> 7 -5135 1305 40 50
#> 8 -5505 1190 55 70
#> 9 -5705 1430 90 40
#> 10 -5645 1535 52 60
加载更多需要的包
library(ggforce) # devtools::install_github("thomasp85/ggforce")
执行
ggplot(tbl, aes(x0 = X, y0 = Y, a = Diameter_E_W, b = Diameter_N_S, angle = 0)) +
geom_ellipsis() + geom_point(aes(X, Y), size = .5) + coord_fixed() + theme_bw()