By default, it seems that ggplot2 uses a minor grid that is just half of the major grid. Is there any way to to break this up?
For example, I have a plot where the x-axis is years, and the major breaks are (1850, 1900, 1950, 2000). This means the minor grid points are at (1875, 1925, 1975), which is a little unintuitive for years. How can I make the minor grid appear at every decade?
The panel. grid. major allows you to customize the major grid of the panel. library(ggplot2) ggplot(data = mtcars, aes(x = hp, y = mpg)) + geom_point() + theme(panel.grid.major = element_line(color = "red", size = 0.5, linetype = 2)) Appending .
You need to use scale_x_continuous() and scale_y_continuous() with breaks and minor_breaks parameters. Parameter breaks will add major gridlines whereas minor_breaks will add minor gridlines.
On value axes, major grid lines are drawn for every major axis division. Minor grid lines separate the units delineated by major grid lines. Minor grid lines, which can only appear on value axes, appear for every minor axis division. By default, major grid lines appear for value axes.
To remove a particular panel grid, use element_blank() for the corresponding theme argument. For example to remove the major grid lines for the x axis, use this: p + theme(panel. grid.
You do it by explicitly specifying minor_breaks()
in the scale_x_continuous
. Note that since I did not specify panel.grid.major
in my trivial example below, the two plots below don't have those (but you should add those in if you need them). To solve your issue, you should specify the years either as a sequence or just a vector of years as the argument for minor_breaks()
.
e.g.
ggplot(movies, aes(x=rating)) + geom_histogram() + theme(panel.grid.minor = element_line(colour="blue", size=0.5)) + scale_x_continuous(minor_breaks = seq(1, 10, 1))
ggplot(movies, aes(x=rating)) + geom_histogram() + theme(panel.grid.minor = element_line(colour="blue", size=0.5)) + scale_x_continuous(minor_breaks = seq(1, 10, 0.5))
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With