将geom_bar的默认宽度更改为另一个默认值

aga*_*ues 5 r width bar-chart ggplot2 ggproto

我想做的事

目前,我的绘图有一个自定义主题,我想在此基础上为所有类型的绘图提供一些预定义的参数。我首先关注的是条形图,我想在其中更改默认宽度。

ggplot2中geom_bar的默认宽度为“ 默认情况下,设置为数据分辨率的90%。 ”(http://ggplot2.tidyverse.org/reference/geom_bar.html)。

我想将默认值更改为75%。需要明确的是,我希望这样更改它:

geom_bar(stat='identity', width=0.75)

因为那意味着我每次创建条形图时都必须指定它。我希望它是新的默认值。

到目前为止我尝试过的

我尝试使用此方法更改默认宽度:

update_geom_defaults("bar", list(width=0.75))

但随后我收到一条错误消息:Error: Aesthetics must be either length 1 or the same as the data (964): width。我在想这可能是由于宽度是根据数据的分辨率计算出来的,在我打电话的那一刻还没有update_geom_defaults

另外,我还意识到这width不是bar的默认aes的一部分:

GeomBar$default_aes
* colour   -> NA
* fill     -> "grey35"
* size     -> 0.5
* linetype -> 1
* alpha    -> NA
Run Code Online (Sandbox Code Playgroud)

我的问题是:

  • 90%的默认设置在哪里?
  • 我可以以任何方式更改它吗?
  • 如果不是,是否还有另一种方法可以将预定义的参数集传递给所有geom_ *函数?

谢谢 !

Axe*_*man 5

默认值定义在GeomBar

GeomBar <- ggproto("GeomBar", GeomRect,
  required_aes = c("x", "y"),

  setup_data = function(data, params) {
    data$width <- data$width %||%
      params$width %||% (resolution(data$x, FALSE) * 0.9)  ## <- right here
    transform(data,
      ymin = pmin(y, 0), ymax = pmax(y, 0),
      xmin = x - width / 2, xmax = x + width / 2, width = NULL
    )
  },

  draw_panel = function(self, data, panel_params, coord, width = NULL) {
    # Hack to ensure that width is detected as a parameter
    ggproto_parent(GeomRect, self)$draw_panel(data, panel_params, coord)
  }
)
Run Code Online (Sandbox Code Playgroud)

标记的行使用%||%,用于在事件params$width为中设置默认值NULL(这是中的默认值geom_barNULL表示“将其设置为对我来说合理的值”)。

没有什么好方法update_geom_defaults可以更改此设置。您可以做的是geom_bar像这样制作自己的:

geom_bar75 <- function (..., width = 0.75) {
  geom_bar(..., width = width)
}
Run Code Online (Sandbox Code Playgroud)

这在大多数情况下都可以正常工作,即使用离散的x轴(因为分辨率为1)。对于更复杂的情况,您可能需要调整或重新定义GeomBar自身。

ggplot(mpg, aes(class)) + geom_bar()
ggplot(mpg, aes(class)) + geom_bar75()
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明