How to fix the aspect ratio in ggplot?

前端 未结 3 1114
忘了有多久
忘了有多久 2020-11-30 20:18

I\'m trying to resize a plot to fit into my document, but I\'m having difficulties getting the plotted diagram do be a square.

Example:

pdf(file = \"         


        
相关标签:
3条回答
  • 2020-11-30 20:39

    To ensure a particular aspect ratio, e.g. for square, use theme(aspect.ratio=1).

    Andrie's answer doesn't give the full picture, as the example provides perhaps unnatural data where range of x equals the range of y. If however the data were:

    df <- data.frame(
      x = runif(100, 0, 50),
      y = runif(100, 0, 5))
    ggplot(df, aes(x=x, y=y)) + geom_point() + coord_fixed()
    

    then the plot would look like this:

    enter image description here

    The coord_fixed() function also has an argument to adjust the ratio of axes:

    ratio aspect ratio, expressed as y / x

    So that the plot could be made square with:

    ggplot(df, aes(x=x, y=y)) + geom_point() + coord_fixed(ratio=10)
    

    enter image description here

    But you need to adjust this with the limits of the variables or plot area (not all limits are nicely divisible by whole numbers like these examples).

    0 讨论(0)
  • 2020-11-30 20:47

    In ggplot the mechanism to preserve the aspect ratio of your plot is to add a coord_fixed() layer to the plot. This will preserve the aspect ratio of the plot itself, regardless of the shape of the actual bounding box.

    (I also suggest you use ggsave to save your resulting plot to pdf/png/etc, rather than the pdf(); print(p); dev.off() sequence.)

    library(ggplot2)
    df <- data.frame(
        x = runif(100, 0, 5),
        y = runif(100, 0, 5))
    
    ggplot(df, aes(x=x, y=y)) + geom_point() + coord_fixed()
    

    enter image description here

    0 讨论(0)
  • 2020-11-30 20:50

    For completeness sake: If you want to take very different axis limits into account:

    df <- data.frame(
      x = runif(100, 0, 5000),
      y = runif(100, 0, 5))
    ratio.display <- 4/3
    ratio.values <- (max(df$x)-min(df$x))/(max(df$y)-min(df$y))
    plot <- ggplot(df, aes(x=x, y=y)) + geom_point()
    plot + coord_fixed(ratio.values / ratio.display)
    

    Resulting in:

    0 讨论(0)
提交回复
热议问题