4

我想将标注文本添加到我的 R 图中。例如,我有一些情节:

x <- seq(0, 2, by=0.1)
y <- x*x
plot(x, y, type="l")

在此处输入图像描述

我想添加一些这样的标注文本:

在此处输入图像描述

有一些标准的方法吗?

4

2 回答 2

5

看看?text(和?arrows)。

x <- seq(0, 2, by=0.1)
y <- x*x
plot(x, y, type="l")

text(0.25, 2, "Some text", pos=3)
arrows(0.25, 2, 1, 1)

标注图1

更新

您可以将text,lines和组合arrows成一个小函数:

x <- seq(0, 2, by=0.1)
y <- x*x
plot(x, y, type="l")

# x0, y0: coordinates of text; see ?text
# x1, y1: coordinates to which the arrows are drawn; see ?arrows
# labels: text
# vOffset/hOffset: vertical/horizontal offset
callout <- function(x0, y0, x1, y1, labels, vOffset=0.25, hOffset=0.25) {
  ## fetch labels width/height
  w <- strwidth(labels)
  w2 <- w/2
  h <- strheight(labels)
  h2 <- h/2

  ## draw text
  text(x0, y0, labels=labels)

  ## calulate arrow starting point/line end point
  x01 <- x0+w2*(1+hOffset)
  y01 <- y0-h2*(1+vOffset)

  ## draw horizontal lines
  for (i in seq(along=x0)) {
    lines(c(x0[i]-w2[i], x01[i]), c(y01[i], y01[i]))
  }

  ## draw arrows
  arrows(x0=x01, y0=y01, x1=x1, y1=y1)
}

callout(c(0.25, 0.25), c(2, 3), c(1, 1.5), c(1, 2.25),
        c("Some text", "Some other text"))

标注图2

于 2013-06-30T10:42:03.653 回答
2

为了准确重现,我还会使用lines

在此处输入图像描述

x <- seq(0, 2, by=0.1)
y <- x*x
plot(x, y, type="l")
text(0.25,2.2,'Some text')
lines(c(0, 0.5,1), c(2 ,2,1),
      lwd=3, col="grey")

arrows(0.5,2,1,1,
  lwd=3, col="grey")
于 2013-06-30T11:23:52.760 回答