Ярлыки оси вращения и расстояния в ggplot2 - PullRequest
565 голосов
/ 26 августа 2009

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

data(diamonds)
diamonds$cut <- paste("Super Dee-Duper",as.character(diamonds$cut))
q <- qplot(cut,carat,data=diamonds,geom="boxplot")
q + opts(axis.text.x=theme_text(angle=-90))

enter image description here

Ответы [ 5 ]

963 голосов
/ 26 августа 2009

Изменить последнюю строку на

q + theme(axis.text.x = element_text(angle = 90, hjust = 1))

По умолчанию оси выровнены по центру текста, даже при повороте. При повороте на +/- 90 градусов обычно требуется, чтобы он был выровнен по краю:

alt text

Изображение выше из этого блога .

79 голосов
/ 20 декабря 2010

Чтобы сделать текст на метках тиков полностью видимым и читать в том же направлении, что и метка оси Y, измените последнюю строку на

q + theme(axis.text.x=element_text(angle=90, hjust=1))
72 голосов
/ 01 августа 2017

Использование coord_flip()

data(diamonds)
diamonds$cut <- paste("Super Dee-Duper",as.character(diamonds$cut))

qplot(cut,carat,data = diamonds, geom = "boxplot") +
  coord_flip()

enter image description here


В гл. 3.9 из R для науки о данных Уикхем и Гролемунд говорят на этот точный вопрос:

coord_flip() переключает оси x и y. Это полезно (например), если вы хотите горизонтальные боксы. Это также полезно для длинных этикеток: их трудно уместить, не перекрывая ось X.

22 голосов
/ 02 мая 2016

Я бы хотел предложить альтернативное решение, поскольку в последней версии ggtern требовалось надежное решение, подобное тому, что я собираюсь предложить, с момента появления функции поворота холста.

По сути, вам нужно определить относительные положения с помощью тригонометрии, построив функцию, которая возвращает element_text объект, заданный угол (т.е. градусы) и информацию о расположении (то есть одну из x, y, сверху или справа).

#Load Required Libraries
library(ggplot2)
library(gridExtra)

#Build Function to Return Element Text Object
rotatedAxisElementText = function(angle,position='x'){
  angle     = angle[1]; 
  position  = position[1]
  positions = list(x=0,y=90,top=180,right=270)
  if(!position %in% names(positions))
    stop(sprintf("'position' must be one of [%s]",paste(names(positions),collapse=", ")),call.=FALSE)
  if(!is.numeric(angle))
    stop("'angle' must be numeric",call.=FALSE)
  rads  = (angle - positions[[ position ]])*pi/180
  hjust = 0.5*(1 - sin(rads))
  vjust = 0.5*(1 + cos(rads))
  element_text(angle=angle,vjust=vjust,hjust=hjust)
}

Честно говоря, на мой взгляд, я думаю, что опция 'auto' должна быть доступна в ggplot2 для аргументов hjust и vjust, когда задаешь угол, во всяком случае, давайте продемонстрируем, как работает выше.

#Demonstrate Usage for a Variety of Rotations
df    = data.frame(x=0.5,y=0.5)
plots = lapply(seq(0,90,length.out=4),function(a){
  ggplot(df,aes(x,y)) + 
    geom_point() + 
    theme(axis.text.x = rotatedAxisElementText(a,'x'),
          axis.text.y = rotatedAxisElementText(a,'y')) +
    labs(title = sprintf("Rotated %s",a))
})
grid.arrange(grobs=plots)

Который производит следующее:

Example

4 голосов
/ 07 ноября 2018

Пакет ggpubr предлагает ярлык, который делает правильные вещи по умолчанию (выравнивание текста по правому краю, текстовое поле по центру по галочке):

library(ggplot2)
diamonds$cut <- paste("Super Dee-Duper", as.character(diamonds$cut))
q <- qplot(cut, carat, data = diamonds, geom = "boxplot")
q + ggpubr::rotate_x_text()

Создано в 2018-11-06 пакетом представ. (v0.2.1)

Найдено с помощью GitHub для поиска соответствующих имен аргументов: https://github.com/search?l=R&q=element_text+angle+90+vjust+org%3Acran&type=Code

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...