3

我希望能够调整加载标签的位置,使它们不会落在箭头之上。但是,我不知道需要在哪里进行调整。可geom_text用于调整站点位置的位置,但我找不到向量的存储位置str(g)

library(ggplot2)
library(ggfortify)
df <- data.frame(replicate(10,sample(-10:10,10,rep=TRUE)))
names(df) <- c('up','down','left','right','circle','square','triangle','x','r1','l1')
rownames(df) <- paste('Dummy Site', seq(0,9,1))
g <- autoplot(prcomp(df[,-11], scale=TRUE), data=df,
              loadings.label=TRUE, loadings=TRUE, 
              loadings.label.size=8, loadings.colour='blue',
              label.size=5) +
     geom_text(vjust=-1, label=rownames(df)) +
     theme(plot.background=element_blank(),
           panel.background=element_rect(fill='transparent',color='black',size=1),
           legend.text=element_text(hjust=1),
           legend.key=element_blank()) 
g

我已经查看ggplot2::theme并检查了 的帮助文档autoplot,但找不到任何关于调整标签位置的提及。如果可以根据箭头的矢量进行调整,则可以加分,但可以接受静态调整。

目前,情节如下所示: 上述代码生成的示例

4

1 回答 1

4

您可以通过 获取坐标layer_data(g, 2)。但是autoplot(prcomp.obj)将其他参数传递给ggbiplot(),因此您可以使用 的参数来更改labelloadings.label定位ggbiplot(),例如loadings.label.hjust(参见?ggbiplot)。

示例代码:
arrow_ends <- layer_data(g, 2)[,c(2,4)]

autoplot(prcomp(df[,-11], scale=TRUE), data=df,
         loadings.label=TRUE, loadings=TRUE, 
         loadings.label.size=8, loadings.colour='blue',
         label.size=5, loadings.label.vjust = 1.2) +     # change loadings.label position
     geom_point(data = arrow_ends, aes(xend, yend), size = 3) +  # the coordinates from layer_data(...)
     geom_text(vjust=-1, label=rownames(df)) +
     theme(plot.background=element_blank(),
           panel.background=element_rect(fill='transparent',color='black',size=1),
           legend.text=element_text(hjust=1),
           legend.key=element_blank()) 

在此处输入图像描述

于 2016-10-25T10:10:09.853 回答