Подтвердить что ты не робот

Помещение оси x вверху диаграммы ggplot2

Мне кажется, что это должно быть очевидно... все, что я пытаюсь сделать, это удалить ось x со дна моего графика и добавить его в начало.

Вот пример воспроизводимости. Данные плюс код, чтобы сделать следующий график:

library(reshape2)
library(ggplot2)

data(mtcars)
dat <- with(mtcars, data.frame(mpg, cyl, disp, hp, wt, gear))
cor.matrix <- round(cor(dat, use = "pairwise.complete.obs", method = "spearman"), digits = 2)
diag(cor.matrix)<-NA

cor.dat <- melt(cor.matrix)
cor.dat <- data.frame(cor.dat)
cor.dat <- cor.dat[complete.cases(cor.dat),]


ggplot(cor.dat, aes(Var2, Var1, fill = value)) + 
  geom_tile(colour="gray90", size=1.5, stat="identity") + 
  geom_text(data=cor.dat, aes(Var2, Var1, label = value), color="black", size=rel(4.5)) +
  scale_fill_gradient(low = "white", high = "dodgerblue", space = "Lab", na.value = "gray90", guide = "colourbar") +
  scale_x_discrete(expand = c(0, 0)) +
  scale_y_discrete(expand = c(0, 0)) +
  xlab("") + 
  ylab("") +
  theme(panel.grid.major = element_blank(),
        panel.grid.minor = element_blank(),
        panel.border = element_rect(fill=NA,color="gray90", size=0.5, linetype="solid"),
        axis.line = element_blank(),
        axis.ticks = element_blank(),
        panel.background = element_rect(fill="gray90"),
        plot.background = element_rect(fill="gray90"),
        legend.position = "none", 
        axis.text = element_text(color="black", size=14) )

enter image description here

Но то, что я пытаюсь создать, похоже, должно быть очевидно (например, это очень легко сделать в base-R), но мне не удалось найти то, что я ищу в ggplot2.

enter image description here

4b9b3361

Ответ 1

Вы можете переместить метки оси x вверх, добавив

scale_x_discrete(position = "top") 

Ответ 2

Я использовал эту работу. Использовал дублированный график по оси X и связал два вместе, а затем обрезал. У меня нет очищенного кода, но ниже приведен пример.

p.bot   <-  
ggplot(cor.dat, aes(Var2, Var1, fill = value)) + 
  geom_tile(colour="gray90", size=1.5, stat="identity") + 
  geom_text(data=cor.dat, aes(Var2, Var1, label = value), color="black", size=rel(4.5)) +
  scale_fill_gradient(low = "white", high = "dodgerblue", space = "Lab", na.value = "gray90", guide = "colourbar") +
  scale_x_discrete(expand = c(0, 0)) +
  scale_y_discrete(expand = c(0, 0)) +
  xlab("") + 
  ylab("") +
  theme(panel.grid.major = element_blank(),
        panel.grid.minor = element_blank(),
        panel.border = element_rect(fill=NA,color="gray90", size=0.5, linetype="solid"),
        axis.line = element_blank(),
        axis.ticks = element_blank(),
        panel.background = element_rect(fill="gray90"),
        plot.background = element_rect(fill="gray90"),
        legend.position = "none", 
        axis.text.x = element_blank(),
        plot.margin = unit(c(1,0,0,0), "cm"),
        axis.text.y = element_text(color="black", size=14) )

p.top   <-  p.bot + theme(
    axis.text.x = element_text(color="black", size=14),
    axis.text.y = element_text(color="gray90", size=14)
    )  + coord_cartesian(ylim = c(0,0))



require(gtable)
#Extract Grobs
g1<-ggplotGrob(p.top)
g2<-ggplotGrob(p.bot)
#Bind the tables
g<-gtable:::rbind_gtable(g1, g2, "first")
#Remove a row between the plots
g <- gtable_add_rows(g, unit(-1.25,"cm"), pos=nrow(g1))
#draw
panels <- g$layout$t[grep("panel", g$layout$name)]
g$heights[panels] <- lapply(c(0,2), unit, "null")

grid.newpage()
grid.draw(g)

enter image description here

Ответ 3

просмотрите пакет cowplot

ggdraw(switch_axis_position(p + axis = 'x'))

Ответ 4

Единственный способ, который я могу сделать, это разобраться с параметром темы vjust для меток оси (и, как я полагаю, и заголовком оси). Что-то вроде:

df <- data.frame(x = 1:10, y = (1:10)^2)       # example data

p <- ggplot(df, aes(x = x, y = y)) + geom_point() +
    theme(
        axis.text.x = element_text(vjust = -5),
        axis.title.x = element_text(vjust = -5))

vjust не работает с element_text, тем не менее, поэтому я застреваю при перемещении тиков оси.