8

我正在尝试在天空上绘制天体(基本上坐标相当于纬度/经度)。我使用函数的"aitoff"投影成功地绘制了我的所有点coord_map,但在这种情况下,网格的显示效果很差,即对于不等于零的纬度,剩余的水平线仍然显示,以及它们的正确投影。

在此处输入图像描述

我怎样才能删除这些行?

这是重现该行为的代码:

library(ggplot2)
library(mapproj)
sky2 = data.frame(RA=0, Dec=0)
skyplot2 <- qplot(RA,Dec,data=sky2,xlim=c(0,360),ylim=c(-89.999,89.999),
xlab="R.A.(°)", ylab="Decl. (°)",main="Source repartition on the sky")
skyplot2 + coord_map(projection="aitoff",orientation=c(89.999,180,0)) + 
scale_y_continuous(breaks=(-2:2)*30,limits=c(-89.999,89.999)) + 
scale_x_continuous(breaks=(0:8)*45,limits=c(0,360),
                   labels=c("","","","","","","","",""))
4

2 回答 2

4

绝对这是 ggplot2 中的一个错误,所以你能提交这个错误吗? https://github.com/hadley/ggplot2/issues?state=open 归档为错误

这是一个快速而肮脏的hack。

f <- function(x, y, ...) {
    if (any(is.na(x))) {
    id <- rle(!is.na(x))$length
    id <- rep(seq_along(id), id)
    df <- data.frame(x, y, id)
    df <- df[order(df$id, df$x), ]
  } else if (any(is.na(y))) {
    id <- rle(!is.na(y))$length
    id <- rep(seq_along(id), id)
    df <- data.frame(x, y, id)
  }
  polylineGrob(df$x, df$y, id = df$id, gp = gpar(col = "white"))
}

skyplot2 <- qplot(RA,Dec,data=sky2,xlim=c(0,360),ylim=c(-89.999,89.999),
                  xlab="R.A.(°)", ylab="Decl. (°)",main="Source repartition on the sky")
skyplot2 + coord_map(projection="aitoff",orientation=c(89.999,180,0)) + 
  scale_y_continuous(breaks=(-2:2)*30,limits=c(-89.999,89.999)) + 
  scale_x_continuous(breaks=(0:8)*45,limits=c(0,360),
                     labels=c("","","","","","","","","")) +
                    opts(panel.grid.major = f)

在此处输入图像描述

请注意,这可能仅适用于 aitoff 投影。

于 2012-05-23T02:01:37.773 回答
2

您只需要添加:

+ opts(axis.ticks = theme_blank())
于 2012-05-22T22:08:35.313 回答