昨天,我问question关于如何绘制多条(水平线)线,每条线都有用户指定的颜色,而不使用循环。
我尝试使用建议的函数matplot()绘制下图中显示的短垂直线以及相关代码。
ci = matrix(1:30, nrow=3, byrow=T)
ci=list(rbind(ci[1,], ci[1,]+2),
rbind(ci[2,], ci[2,]+2),
rbind(ci[3,], ci[3,]+2))
x = rbind(1:10, 1:10)
plot(-5, xlim=c(1,10), ylim=c(1,32))
invisible(mapply(matlines, x=list(x), y=ci,
col=c("red","blue","black"),
lty = 1))
这一切都很好。但是,我试图将此代码包装在一个函数中,我希望能够输入一个可选参数列表,然后可以将其传递给mapply / matlines。我试图在mapply()中使用参数MoreArgs无济于事。似乎MoreArgs采用的论点与其他论点不一样。正如您在第一个代码中看到的,列表中的每个项目都有不同的颜色,但是当我将col放在列表args.ci中时,3个颜色在列表的每个项目中被回收。我想知道是否有任何方法可以解决这个问题,这样如果我有一个参数的多个值,每个值都会应用于列表的一个项目。谢谢!
args.ci = list(col=c("red","blue","black"), lty=1:3)
plot(-5, xlim=c(1,10), ylim=c(1,32))
invisible(mapply(matlines, x=list(x), y=ci,
MoreArgs = args.ci))
答案 0 :(得分:5)
这是解决此类问题的一般方法。您应该能够对其进行调整以更准确地执行您想要的操作:
myFun <- function(...) {
fixedArgs <- list(matlines, x=list(x), y=ci)
dots <- list(...)
allArgs <- c(fixedArgs, dots)
plot(-5, xlim=c(1,10), ylim=c(1,32))
invisible(do.call(mapply, allArgs))
}
myFun(col=c("red","blue","black"), lty=1)