繁体   English   中英

ggplot2中的透明屏蔽

[英]Transparent masking in ggplot2

我对如何仅在功能区附近包含面板网格线感兴趣 - 我可以手动执行此操作,这是一个简单的例子

library(ggplot2)

d1 <- data.frame(x = seq(0, 1, length.out = 200))
d1$y1 <- -3*(d1$x-.5)^2 + 1
d1$y2 <- -3*(d1$x-.5)^2 + 2

ggplot(d1) +
 geom_ribbon(aes(x, ymin = y1, ymax = y2),
             alpha = .25) +
 geom_ribbon(aes(x, ymax = y1),
             ymin = .25, 
             fill = "white") +
 geom_ribbon(aes(x, ymin = y2),
            ymax = 2, 
            fill = "white") +
 scale_y_continuous(limits = c(.25, 2.0),
                    expand = c(0, 0))+
scale_x_continuous(limits = c(0, 1),
                   expand = c(0, 0))+
theme_bw() +
theme(panel.grid = element_line(linetype = 1, color = "black")) 

剪辑的例子

是否有一些不太常见的方法为这些网格线设置透明遮罩,所以它们只出现在一个色带下面?

如果网格线与背景颜色相同,则可以删除实际网格线,然后使用geom_hline()geom_vline()创建自己的“网格线”,这些网格线将显示在色带上但在背景中不可见

d1$y3 <- d1$x + 0.3
d1$y4 <- d1$x + 0.4

ggplot(d1) +
  geom_ribbon(aes(x, ymin = y1, ymax = y2), alpha = 0.25) +
  geom_ribbon(aes(x, ymin = y3, ymax = y4), alpha = 0.25, fill = "blue") +
  # use geom_vline and geom_hline to plot "gridlines" on top of ribbons
  geom_hline(yintercept = seq(0, 2, by = 0.25), colour = "white") +
  geom_vline(xintercept = seq(0, 1, by = 0.25), colour = "white") +
  scale_y_continuous(limits = c(.25, 2.0), expand = c(0, 0)) +
  scale_x_continuous(limits = c(0, 1), expand = c(0, 0)) +
  theme_bw() +
  theme(panel.grid.minor = element_blank(), # remove actual gridlines
        panel.grid.major = element_blank())

产生这个: 在此输入图像描述

这仍然是一种解决方法,并且只会使网格线与背景颜色相匹配,但它很容易使用各种图表,例如您提到的多条色带的情况(我添加了第二个色带来证明这一点将工作)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM