Отключение обрезки ggplot удаляет сегмент линии

Я пытаюсь нарисовать несколько стрелок на полях ggplot. Из того, что я читал, для этого нужно отключить отсечение сюжета. Однако, когда я это делаю, он удаляет сегмент линии, который у меня есть на моем графике.

library(ggplot2)
library(ggrepel)
library(grid)

#----------------- Fake data practice --------------------- #

mydata <- data.frame(Labels = letters[1:14],
                     X_Values = seq(1, 14, 1),
                     Y_Values = rnorm(14, mean = 0, sd = 1),
                     Influence = seq(1, 14, 1))


mydata$Influencer <- factor(ifelse(mydata$Influence <= 3, 1, 0))

# --- Get min/max from data and use to set range at -1to1 or -2to2

chartMax <- ifelse(min(mydata$Y_Values) < -1 | max(mydata$Y_Values) > 1, 2, 1)
chartMin <- ifelse(chartMax == 1, -1, -2)

yTitle = "Some Title"
# --- Label setting, if greater than 0 nudge up, else nudge down

mydata$Nudger <- ifelse(mydata$Y_Values >= 0, .1, -.1)


p <- ggplot(mydata, aes(x = X_Values, y = Y_Values, group = Influencer)) +
        geom_point(aes(size = Influencer, color = Influencer), shape = 18) +
        geom_segment(x = 0, xend = 14, y = 0, yend = 0, color = "red", linetype = "dashed", size = 1.2, alpha = .5) +
        geom_text_repel(aes(x = X_Values, y = Y_Values, label = Labels),
                        box.padding = .4,
                        point.padding = .2,
                        nudge_y = .1) +
        scale_color_manual(values = c("grey", "blue")) + 
        scale_size_manual(values = c(4, 6)) +
        scale_y_continuous(name = "", limits = c(chartMin, chartMax)) + 
        scale_x_continuous(name = yTitle,
                           limits = c(1, 15),
                           breaks = c(2,13),
                           labels = c("Lower", "Higher")) +
        theme_classic() + theme(plot.margin = unit(c(1,3,1,2), "lines"),
                                legend.position="none",
                                axis.ticks.x=element_blank(),
                                axis.text.x = element_text(face = "bold"),
                                axis.title = element_text(face = "bold"),
                                axis.line.x = element_line(color = "blue"
                                                           ,size = 1
                                                           ,arrow = 
                                                             arrow(length = unit(0.5, "cm"),
                                                                   ends = "both"))) +
        annotation_custom(
          grob = linesGrob(arrow=arrow(type="open", ends="both", length=unit(0.5, "cm")), gp=gpar(col="blue", lwd=2)), 
          xmin = -1.4, xmax = -1.4, ymin = chartMin, ymax = chartMax
        ) 

p
# Here it works and you see the red dashed line

# Turn off panel clipping
gt <- ggplot_gtable(ggplot_build(p))
gt$layout$clip[gt$layout$name == "panel"] <- "off"
grid.draw(gt)

В идеале мне нужна синяя стрелка, которая проходит вдоль оси Y на полях. Я думаю, что у меня это есть, но я не могу потерять мою пунктирную красную линию, которая проходит внутри графика.


person James Holland    schedule 21.11.2017    source источник
comment
альтернативным маршрутом было бы добавление стрелок за пределы панели либо путем пост-обработки объекта gtable, либо с помощью пользовательской оси grob stackoverflow.com /a/27149233/471093   -  person baptiste    schedule 21.11.2017


Ответы (1)


Я не могу объяснить, почему это происходит (похоже на ошибку, предлагаю поднять вопрос здесь), но я могу подтвердить, что проблема связана с альфа-строкой. Если мы удалим аргумент alpha = 0.5 из geom_segment, то clipping=off будет работать без удаления строки:

введите здесь описание изображения

person dww    schedule 21.11.2017