【问题标题】:texture in geom_polygon fillgeom_polygon 填充中的纹理
【发布时间】:2017-10-28 18:13:38
【问题描述】:

我需要创建一张欧洲地图来显示变量在不同国家/地区的分布。我需要黑白地图。我依靠ggplot 并以approach 为例。我根据this blogpost更改了图例。所有这些都适用于这个结果:

我的问题是如何更改地图,以使我缺少填充信息并显示为纯白色的国家/地区具有纹理(我正在考虑对角线)?

由于我的脚本有点乱,这里只展示ggplot,没有数据准备部分:

require(ggplot2)

plotCoords <- read.csv("http://eborbath.github.io/stackoverflow/PlotCoords.csv")
showCoords <- read.csv("http://eborbath.github.io/stackoverflow/showCoords.csv")


ggplot() +
  geom_polygon(
    data = plotCoords,
    aes(x = long, y = lat, group = group),
    fill = "white", colour = "darkgrey", size = 0.6) +
  geom_polygon(
    data = showCoords,
    aes(x = long, y = lat, group = group),
    fill = "grey", colour = "black", size = 0.6) +
  geom_polygon(
    data = showCoords,
    aes(x = long, y = lat, group = group, fill = sh_left),
    colour = "black", size = 0.1) +
  scale_fill_gradient(
    low = "gray90", high = "gray0",
    name = "Share of left-wing protesters",
    guide = guide_colorbar(
      direction = "horizontal",
      barheight = unit(2, units = "mm"),
      barwidth = unit(50, units = "mm"),
      draw.ulim = F,
      title.position = 'top',
      title.hjust = 0.5,
      label.hjust = 0.5
    )) +
  scale_x_continuous(element_blank(), breaks = NULL) +
  scale_y_continuous(element_blank(), breaks = NULL) +
  coord_map(xlim = c(-26, 47),  ylim = c(32.5, 73)) + 
  theme_bw() +
  theme(legend.justification = c(-0.4, 1.2), legend.position = c(0, 1))

第一个geom_polygon 用于背景,我想我必须在那里编辑fill。显然,这对于将没有信息与我绘制的变量的低值区分开来很重要。鉴于我必须依赖黑白,我想出了使用纹理的想法,但我愿意接受其他建议。

谢谢!

【问题讨论】:

  • 我担心 ggplot2 可能无法使用纹理,遵循 Hadley 对 this related question 的回答。不过那已经很老了,所以也许现在已经实现了!
  • 尽管如此,我认为您并不真正需要纹理来分隔没有数据的国家/地区。它们已经是带有灰色边框的纯白色,与变量值较低的国家/地区的浅灰色和黑色边框形成鲜明对比。情节看起来不错!

标签: r ggplot2 data-visualization


【解决方案1】:

它是technically possible with gridSVG,但不确定是否值得。

我基于GeomPolygon新建了一个geom,修改draw_panel方法返回,

gl <- by(munched, munched$group, 
         function(m){
           g <- polygonGrob(m$x, m$y, default.units = "native")

           patternFillGrob(g, 
                           pattern = pattern(linesGrob(gp=gpar(col="red",lwd=3)),
                                             width = unit(2, "mm"), height = unit(2, "mm"),
                                             dev.width = 1, dev.height = 1))
         }, simplify = FALSE)

gTree(children = do.call(gList, gl))

【讨论】:

  • 如果有人有动力进一步推动这一点,请在此处进行代码实验gist.github.com/baptiste/2e38056222a9b95fbf0723b26100b110
  • 非常感谢!您能否指出一些有关如何使用grid.export 调整svg 绘图大小的资源?我从来没有用过这个。理想情况下,我想将其导出到 .eps.png
  • 我已经尝试过 ggsaveplot_save 包中的 plot_save 命令,但它们都没有显示动画。在我看来,grid.export 只能调整分辨率而不能调整尺寸;因此图例放错了位置等。理想情况下,我只想使用具有合理 dpi 的 6 * 8 英寸。我该怎么做?
  • rootAttrs 可以让您调整高度和视图框,但图例不显示。大概是一个错误,您可以联系包维护人员(我认为 grid.force() 可能会有所帮助;它没有)
  • 谢谢!最后我做到了:gridsvg(name = "path//filename.svg", res = 400, width=8, height=6) p dev.off(which = dev.cur()) ,以防有人想要复制。
猜你喜欢
  • 1970-01-01
  • 2014-10-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-07-17
  • 2016-03-02
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多