删除R Spie图中的标签边框

问题描述 投票:2回答:1

这是我的代码

require(caroline)
   x <- c(100, 90, 80, 15, 120, 25)
   y <- c(120, 120, 60, 10, 120, 15)
   names(x) <- c("Mark_1", "Mark_2", "Mark_3", "Mark_4", "Mark_5", "Mark_6")
   spie.sales <- spie(x, y,col=rainbow(length(x)),bg=c("black", "violetred1", 
                                                       "cornsilk","red", "green", "white"))

如何删除标签周围的边框(Mark_1,Mark_2等)?

这是我在绘图时得到的图像

r plot label
1个回答
2
投票

虽然在加载fixInNamespace包之前可以使用函数spie来修改caroline函数,但我更喜欢修改函数的副本。

## Create copy of spie
spie2 <- spie

此外,您可以保留绘制矩形的选项。因此,在这里将新的参数labRects添加到新函数中。当此对象的值为FALSE时,不会绘制矩形。当TRUE,原始情节产生。

## Add new argument to spie2 function
formals(spie2) <- c(formals(spie), labRects = FALSE)

然后找到body函数的哪个部分需要改变并改变它

## Assign new code into the appropriate part of the body of the function
body(spie2)[[9]][[4]][[8]][[3]][[2]] <- substitute({
    if(labRects) {
        grid.rect(x = cos(angleAnn) * maxx, y = sin(angleAnn) * maxx, 
            width = 1.5 * stringWidth(x$namesSlices[i]), height = 1.5 * 
            stringHeight(x$namesSlices[i]), default.units = "native", 
            gp = gpar(col = col[i], fill = "white", lwd = 2))
    }
})

因为,正如Zbynek指出的那样,spie函数和新的spie2函数都依赖于.spie包中的非导出"caroline"函数,我们需要改变spie2的环境以匹配spie的环境以允许访问.spie函数。

## Change environment of spie2 to "caroline"
environment(spie2) <- environment(spie)

## ...and plot
spie.sales <- spie2(x, y,col=rainbow(length(x)),
  bg=c("black", "violetred1", "cornsilk","red", "green", "white"),
  labRects = FALSE)

© www.soinside.com 2019 - 2024. All rights reserved.