Как дрожать текст, чтобы избежать перекрытия в ggplot2 диаграмма рассеяния?

Я хотел бы создать чистую версию диаграммы рассеивания текстовых меток в ggplot2. Цель состоит в том, чтобы визуально представить возрастающие значения, связанные примерно с 25 элементами. Я уже использую "position_jitter, " но мне интересно, смогу ли я сделать лучше.

Вот некоторые фиктивные данные:

title <- rep("A Really Rather Long Text Label", 25)
value <- runif(25, 1,10)
spacing <- seq(1:25)
df <- data.frame(title, value, spacing, stringsAsFactors = FALSE)

А вот код, который генерирует график:

library(ggplot2)
myplot <- ggplot(data=df, aes(x=spacing, y=value, label = title)) +
geom_text(aes(colour = value),
    size = 2.5, fontface = "bold",
    vjust = 0,
    position = position_jitter(width=5, height=0)) +
theme_bw() +
scale_x_continuous(limits = c(-5, 30))+
scale_colour_gradient(low = "#6BAED6", high = "#08306B") +
theme(axis.title.x = element_blank(),
      axis.ticks = element_blank(),
      axis.text.x = element_blank(),
      legend.position = "none")
myplot

Для всего этого текста достаточно места на графике разумных размер -- до тех пор, пока текст может смещаться настолько далеко, насколько это необходимо по горизонтали!

Каждый раз, когда вы запускаете команду ggplot, график выглядит несколько иначе, и иногда результаты дрожания лучше, чем в других случаях. Но я не нашел способа систематически предотвращать перекрытие меток.

Буду признателен за любые предложения по очистке горизонтального позиционирования текста без необходимости вручную перемещать отдельные элементы. Я также был бы рад услышать другие советы о том, как улучшить этот тип визуального представления.

35
задан C8H10N4O2 20 October 2014 в 15:20
поделиться