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)
我的问题是:
谢谢 !
默认值定义在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_bar,NULL表示“将其设置为对我来说合理的值”)。
没有什么好方法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)