FMM*_*FMM 4 r ggplot2 patchwork
当ggplot2使用拼凑组合对象时,我希望能够有一个选项,我可以轻松地为所有图设置一个选项,使其具有相同的 x 轴和/或 y 轴范围。
代表:
library(patchwork)
library(ggplot2)
library(dplyr)
#>
#> Attaching package: 'dplyr'
#> The following objects are masked from 'package:stats':
#>
#> filter, lag
#> The following objects are masked from 'package:base':
#>
#> intersect, setdiff, setequal, union
p1 <- mtcars %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 1')
p2 <- mtcars %>%
filter(disp < 300) %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 2')
p1 + p2
Run Code Online (Sandbox Code Playgroud)

由reprex 包(v0.3.0)于 2020 年 2 月 1 日创建
预期结果将其设置为在两个图中具有相同范围的两个轴:
library(patchwork)
library(ggplot2)
library(dplyr)
#>
#> Attaching package: 'dplyr'
#> The following objects are masked from 'package:stats':
#>
#> filter, lag
#> The following objects are masked from 'package:base':
#>
#> intersect, setdiff, setequal, union
p1 <- mtcars %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 1')
p2 <- mtcars %>%
filter(disp < 300) %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 2') +
xlim(ggplot_build(p1)$layout$panel_scales_x[[1]]$range$range) +
ylim(ggplot_build(p1)$layout$panel_scales_y[[1]]$range$range)
p1 + p2
Run Code Online (Sandbox Code Playgroud)

由reprex 包(v0.3.0)于 2020 年 2 月 1 日创建
有没有人有任何想法?
FMM*_*FMM 10
好吧,我很抱歉回答我自己的问题,但我刚刚找到了解决方案..
这可以通过使用 来很好地实现&,它将函数应用于拼凑对象中的所有图。
1)reprex:
library(patchwork)
library(ggplot2)
library(dplyr)
#>
#> Attaching package: 'dplyr'
#> The following objects are masked from 'package:stats':
#>
#> filter, lag
#> The following objects are masked from 'package:base':
#>
#> intersect, setdiff, setequal, union
p1 <- mtcars %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 1')
p2 <- mtcars %>%
filter(disp < 300) %>%
ggplot() +
geom_point(aes(mpg, disp)) +
ggtitle('Plot 2')
p_combined <- p1 + p2
p_combined
Run Code Online (Sandbox Code Playgroud)

由reprex 包(v0.3.0)于 2020 年 2 月 1 日创建
2)从范围中获取最小值和最大值:
p_ranges_x <- c(ggplot_build(p_combined[[1]])$layout$panel_scales_x[[1]]$range$range,
ggplot_build(p_combined[[2]])$layout$panel_scales_x[[1]]$range$range)
p_ranges_y <- c(ggplot_build(p_combined[[1]])$layout$panel_scales_y[[1]]$range$range,
ggplot_build(p_combined[[2]])$layout$panel_scales_y[[1]]$range$range)
Run Code Online (Sandbox Code Playgroud)
3) 将这些范围应用于拼凑对象:
p_combined &
xlim(min(p_ranges_x), max(p_ranges_x)) &
ylim(min(p_ranges_y), max(p_ranges_y))
Run Code Online (Sandbox Code Playgroud)

由reprex 包(v0.3.0)于 2020 年 2 月 1 日创建
小智 5
这里稍微修改一下,将上面的操作变成一个函数:
apply_consistent_y_lims <- function(this_plot){
num_plots <- length(this_plot$layers)
y_lims <- lapply(1:num_plots, function(x) ggplot_build(this_plot[[x]])$layout$panel_scales_y[[1]]$range$range)
min_y <- min(unlist(y_lims))
max_y <- max(unlist(y_lims))
this_plot & ylim(min_y, max_y)
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1247 次 |
| 最近记录: |