Я бы предпочел сделать это таким образом.Нарисуйте один нормальный сюжет и второй увеличенный вариант.Затем наложите их, используя это решение .
p1 <- ggplot(example.data, aes(x=x, y = y)) +
geom_point() +
scale_y_continuous(breaks = example.data$y[1:4], labels = example.data$y.label[1:4])
p2 <- ggplot(example.data, aes(x=x, y = y)) +
geom_point() +
xlim(3.9, 5.1) +
scale_y_continuous(breaks=seq(4.100, 4.111, .002), labels=c("d", rep("", 4), "e"),
limits=c(4.1, 4.111))
vp <- grid::viewport(width=0.4, height=0.15, x=.8, y=.4)
png("plot.png")
print(p1)
print(p2, vp=vp)
dev.off()
Результат
С руководством для читателя становится еще яснее:
library("ggforce")
p1 <- p1 + geom_circle(aes(x0=4.5, y0=4.2, r=.7),
inherit.aes=FALSE, linetype=2) +
geom_segment(aes(x=4.5, y=2.5, xend=4.5, yend=3.5),
size=1, arrow=arrow(length=unit(0.5, "cm")))
Уточненный результат
Примечание: Конечно, вы все еще можете это уточнить, просто чтобы дать вам идею.