2

我正在努力使用我的代码创建一个带有 ggplot2 的条形图,在其中我尝试y在条形顶部添加值,但不移动x轴的标签。 非常适合在条形图上添加值,但是当旋转 45°(即标签的最后一个字母粘在轴上)时geom_text,我无法正确调整轴标签。x

我的数据

 dput(graph)
structure(list(x = structure(1:9, .Label = c("AAAAAAAAAAAAA", 
"BBBBBBBB", "CCCCCCCCCCCCCCCC", "DDDDD", "EEEEEEEE", "FFFFFFF", 
"GGGGGGGGGGGGGGG", "HHHHHHHHHHHHHH", "IIIII"), class = "factor"), 
    y = c(1L, 5L, 10L, 1000L, 20L, 15L, 45L, 30L, 35L)), .Names = c("x", 
"y"), class = "data.frame", row.names = c(NA, -9L))

我的代码:

graph <- read.table("input.txt",header=T,sep=";")
output <- ggplot(graph,aes(x=x,y=y))+
    geom_bar(stat="identity")+
    geom_text(aes(label=y,y=(y+25)))+
    scale_x_discrete()+
    scale_y_continuous(limits=c(0,max(50 + graph$y)))+
    theme(axis.text.x=element_text(angle=45,vjust=0))
print(output)

我无法发布输出的图像,但是除了x轴的刻度线适合标签的中间x而不是标签的最后一个字母之外,该图看起来很好。

4

2 回答 2

4

您应该添加hjust=1axis.text.x=更改vjust=0vjust=1. 要更改条形的外观,您可以尝试使用 y 值的转换,例如平方根,使用scale_y_sqrt(). 仅geom_text()应调整的位置。

output <- ggplot(graph,aes(x=x,y=y))+
  geom_bar(stat="identity")+
  geom_text(aes(label=y,y=(y+c(10,10,10,50,10,10,10,10,10))))+
  scale_y_sqrt(limits=c(0,max(50 + graph$y)),breaks=c(10,100,250,500,1000))+
  theme(axis.text.x=element_text(angle=45,vjust=1,hjust=1))
output

在此处输入图像描述

于 2013-02-16T09:07:06.220 回答
1

这是一个类似 ggplot2 的格子版本:

library(lattice)
library(latticeExtra)
barchart(y~x, data=dat,
         scales = list(x = list(rot=45,cex=1.5)),
         par.settings = ggplot2like(), axis = axis.grid,
         panel=function(x,y,...){
           panel.barchart(x,y,...)
           panel.text(x,y,label=y,col='red',
                      adj=c(0.5,-0.5),cex=2)
         })

在此处输入图像描述

编辑

为了减少条形级别之间的差异,这里的一个想法是使用对数刻度:

library(lattice)
library(latticeExtra)
barchart(y~x, data=dat,
         scales = list(x = list(rot=45,cex=1.5),
                       y = list(log=10)),
         par.settings = ggplot2like(), axis = axis.grid,
         yscale.components = yscale.components.log10ticks,
         panel=function(x,y,...){
           panel.barchart(x,y,...)
           panel.text(x,y,label=10^y,col='red',
                      adj=c(0.5,-0.5),cex=2)
         })

在此处输入图像描述

于 2013-02-16T09:34:13.503 回答