我希望在包加载时定义一组颜色,并在包分离时清除.
我提出的似乎有用的内容显示在以下玩具示例中,该示例依赖于深度分配(我知道这是邪恶的)
.onLoad <- function(libname, pkgname) {
}
.registerColors <- function(){
C.1 <<- c("#FF0000FF", "#80FF00FF", "#00FFFFFF", "#8000FFFF")
C.2 <<- c("#00AAFFFF", "#0000FFFF", "#AA00FFFF", "#FF00AAFF")
}
.onUnload <- function(libpath){
}
.onAttach <- function(libname, pkgname) {
.registerColors()
packageStartupMessage("Welcome to XYZ")
}
.onDetach <- function(libname, pkgname) {
rm(C.1, C.2, pos = 1)
packageStartupMessage("Buh-bye")
}
Run Code Online (Sandbox Code Playgroud)
在这种情况下,情节(seq(1:4,col = C.1)有效.是否有更好或更优雅或更少潜在破坏性的方式来实现它?
你真的不需要去解决所有麻烦.只需定义一个函数来检查包是否已加载,并返回适当的颜色.
chooseCols <- function()
{
if("this_package" %in% search())
C.1
else # use default colours
}
plot(1:4, col=chooseCols())
Run Code Online (Sandbox Code Playgroud)
似乎按照我想要的方式工作的是:
.registerColors <- function(){
assign(x = 'C.1', value = c("#FF0000FF", "#80FF00FF", "#00FFFFFF", "#8000FFFF"), pos = 2)
assign(x = 'C.2', value = c("#00AAFFFF", "#0000FFFF", "#AA00FFFF", "#FF00AAFF"), pos = 2)
}
.onAttach <- function(libname, pkgname) {
.registerColors()
}
Run Code Online (Sandbox Code Playgroud)
现在可以通过名称访问颜色,它们不会出现在全局环境搜索列表中(使我们免于邪恶),因此它们不需要在分离时手动清除,因为它们所在的包环境会自动清除上分离。
这样做的好处是,用户现在可以直接将调色板作为变量访问,而无需调用函数。